在每次 commit 的时候依次建了一个文件:
testA.js
testB.js
testC.js
并且提交记录分别为 A、B、C
初始状态下:
接下来进行测试从 C 回到 B 的提交状态
// -n 后面的是 B 的 commit id
git revert -n 4ef1e6e8c77fba1e5d01ef9200895c03ea0015
执行后发现,有改动,B的文件已经没有了,但是C的文件还在
然后我们提交一个 commit D
这样就完成了一次 revert
执行以下命令
git reset --hard bdaf5516969c2298e43db4a051fa3658f5e1e89
发现直接到 B 了,之前的提交都不见了。
reset 是重置的意思,revert 是恢复、还原的意思。
git reset是将之前的提交记录全部抹去,将 HEAD 指向自己重置的提交记录,对应的提交记录都不复存在;
git revert 操作是将选择的某一次提交记录 重做,若之后又有提交,提交记录还存在,只是将指定提交的代码给清除掉。
选择合适的方式回滚自己的代码,但是要慎重操作,视情况而定,如果 reset 较大就用 revert。