git reset <commit id>
命令,如get reset 831b92
会以特定的顺序重写HEAD
、Index
和Working Directory
。有三个选项:
--soft
仅仅移动HEAD
指针指向提交831b92
。仅仅意思是单纯移动指针,不更新INDEX
索引区,所以此时git status
时会看到绿色的索引区的数据(即上一次提交的内容)。--mixed
会更新INDEX
索引区数据为当前HEAD所指提交对应的快照内容。即此时git status
会看到上一次提交的内容成为本地变化(红色)即在Working Directory
工作目录。--hard
会更新工作目录和索引一样,这样会撤销最后的提交、git add 和 git commit 命令以及工作目录中的所有工作。
必须注意,
--hard
标记是reset
命令唯一的危险用法,它也是 Git 会真正地销毁数据的仅有的几个操作之一。其他任何形式的reset
调用都可以轻松撤消,但是--hard
选项不能,因为它强制覆盖了工作目录中的文件。我们可以通过
reflog
来找回它。但是若该文件还未提交,Git 仍会覆盖它从而导致无法恢复。