git revert
和 git reset
都用于撤销 Git 中的提交,但它们的作用和使用场景不同:
-
git revert
:- 作用:创建一个新的提交,撤销指定的提交内容。
- 使用场景:用于“回滚”已推送到远程仓库的提交。这种方法不会改变提交历史,只是添加一个新的提交,反向操作指定的提交内容。
- 示例:如果你想撤销最后一次提交,但保留历史记录,可以用:
这将创建一个新的提交,该提交撤销git revert HEAD
HEAD
指向的那个提交。
-
git reset
:- 作用:重置当前分支的指针到指定的提交,可以选择是否修改工作区和暂存区的内容。
- 使用场景:用于本地回退到某个提交,常用于撤销未推送到远程仓库的提交。
git reset
会改变历史记录,可能会导致丢失数据,尤其是如果使用了--hard
选项时。 - 示例:
git reset --soft <commit>
:只移动分支指针,不更改工作区和暂存区。适用于想要撤销提交,但保留修改的场景。git reset --mixed <commit>
:移动分支指针并重置暂存区,不更改工作区。适用于希望撤销提交并重新暂存的场景。git reset --hard <commit>
:彻底重置,包括工作区和暂存区的更改。适用于完全撤销某个提交的场景,但要小心,因为数据会丢失。
总结
git revert
适用于已推送的提交,它会创建一个新提交来撤销某个提交的效果,适合多人协作。git reset
适用于本地操作,它可以改变提交历史,并且有多种方式控制是否影响工作区,适合在推送之前进行修改。
你通常会选择 revert
来保持历史不变,而选择 reset
来彻底修改提交历史(仅限本地操作)。