git:revert和reset的区别

测试准备

在每次 commit 的时候依次建了一个文件:
testA.js
testB.js
testC.js
并且提交记录分别为 A、B、C

初始状态下:
git:revert和reset的区别_第1张图片
git:revert和reset的区别_第2张图片
接下来进行测试从 C 回到 B 的提交状态

revert

// -n 后面的是 B 的 commit id
git revert -n 4ef1e6e8c77fba1e5d01ef9200895c03ea0015

执行后发现,有改动,B的文件已经没有了,但是C的文件还在
git:revert和reset的区别_第3张图片
然后我们提交一个 commit D
git:revert和reset的区别_第4张图片
这样就完成了一次 revert

reset

执行以下命令

git reset --hard bdaf5516969c2298e43db4a051fa3658f5e1e89

git:revert和reset的区别_第5张图片
发现直接到 B 了,之前的提交都不见了。

总结

reset 是重置的意思,revert 是恢复、还原的意思。

git reset是将之前的提交记录全部抹去,将 HEAD 指向自己重置的提交记录,对应的提交记录都不复存在;

git revert 操作是将选择的某一次提交记录 重做,若之后又有提交,提交记录还存在,只是将指定提交的代码给清除掉。

选择合适的方式回滚自己的代码,但是要慎重操作,视情况而定,如果 reset 较大就用 revert。

你可能感兴趣的:(#,git,git,github)