Git 之 恢复修改的文件

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

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

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

状况I

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

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

状况II

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

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

 状况III

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

 

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

 

【注1】状况II 和 状况III 只有回退的版本不同,class

对于 状况II,并无 $ git commit,仓库版本也就不会更新和记录,因此回退的是当前版本im

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

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

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

以旧图举例:

相关文章
相关标签/搜索