zoukankan      html  css  js  c++  java
  • Git --恢复修改的文件

    对于恢复修改的文件,就是将文件从仓库中拉到本地工作区,即 仓库区 ----> 暂存区 ----> 工作区。

    对于修改的文件有两种情况:

    • 只是修改了文件,没有任何 git 操作
    • 修改了文件,并提交到暂存区(即编辑之后,gitaddgitadd但没有 git commit -m ....)
    • 修改了文件,并提交到仓库区(即编辑之后,gitaddgitadd和 git commit -m ....)

    情况I:

    只是修改了文件,没有任何 git 操作,直接一个命令就可回退:

    $ git checkout -- aaa.txt # aaa.txt为文件名

    情况II:

    修改了文件,并提交到暂存区(即编辑之后,gitaddgitadd但没有 git commit -m ....)

    $ git log --oneline    # 可以省略
    $ git reset HEAD    # 回退到当前版本
    $ git checkout -- aaa.txt    # aaa.txt为文件名

     情况III:

    修改了文件,并提交到仓库区(即编辑之后,gitaddgitadd和 git commit -m ....)

    $ git log --oneline    # 可以省略
    $ git reset HEAD^    # 回退到上一个版本
    $ git checkout -- aaa.txt    # aaa.txt为文件名

    【注1】情况II 和 情况III 只有回退的版本不一样,

    对于 情况II,并没有 $ git commit,仓库版本也就不会更新和记录,所以回退的是当前版本

    对于情况III,一旦 $ git commit,仓库版本就会更新并记录,所以要回退的也就是上一个版本

    【注2】$ git reset 版本号    ----  将暂缓区回退到指定版本

    根据 $ git log --oneline 显示的版本号(下图黄色的字),可以回退到任何一个版本,也可通过 HEAD 来指定版本(下图红色的字)。

    以旧图举例:

  • 相关阅读:
    HTML3 / 4 / 4.1 / 5 版本升级过程中,变化是怎么样的
    HTML head内所有标签,及其作用
    HTML 和 XHTML和区别
    HTML DOCTYPE 都有哪些,它们之前的区别和用途分别是什么?
    eclipse中英文切换--四种方式
    Eclipse Class Decompiler---Java反编译插件
    jdk历史版本下载
    eclipse优化(部分)
    博客迁移到github
    JavaScript:同步、异步和事件循环
  • 原文地址:https://www.cnblogs.com/hustcser/p/10354712.html
Copyright © 2011-2022 走看看