Revert 和 Reset
总结
一般的使用时,如果已经push了,使用revert,如果没有,就是用reset
一、Revert
git revert
二、Reset
git reset \--soft | --mixed | --hard
--soft 回退时保留源码,仅仅回退 commit,修改的文件仍然保存在暂存区,再次提交时只需要 git commit
--mixed(默认)回退时保留源码,回退 commit 同时修改的文件会置于 工作区,再次提交时需要 git add
--hard 回退时清除提交的源码(危险操作),源码和commit 都会回滚到某个版本
git reset 实际执行的是 HEAD的指向的回退,指定回到某个commit,那么HEAD指针就会回退到对应的 commit。这些操作都是本地执行的,如果想要推送到远程仓库(这是危险操作,因为会修改提交历史),那么需要在push的时候加上强制。
git push --force
区别
revert 使用一个新的commit 来回滚你希望回滚的commit, reset 是直接HEAD 指向回退的commit
revert 只会回滚你希望回滚的哪一个commit的操作,不会影响其他的,reset 由于指针回退了,因此这个commit 之后的commit都会消失。