对于恢复修改的文件,就是将文件从仓库中拉到本地工做区,即 仓库区 ----> 暂存区 ----> 工做区。git
对于修改的文件有两种状况:spa
只是修改了文件,没有任何 git 操做,直接一个命令就可回退:code
$ git checkout -- aaa.txt # aaa.txt为文件名
修改了文件,并提交到暂存区(即编辑以后,$ git add 但没有 $ git commit -m ....)blog
$ git log --oneline # 能够省略
$ git reset HEAD # 回退到当前版本
$ git checkout -- aaa.txt # aaa.txt为文件名
修改了文件,并提交到仓库区(即编辑以后,$ 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
以旧图举例: