回退用 git revert 还是 git reset?

  • git revert 会生成一个新的 commit 来记录此次操作;
  • git reset 是把 HEAD 指针向前挪动一次,会减少一个 commit。

回退用 git revert 回退还是用 git reset,核心就一点:
是否需要记录这次回退

如果需要记录这次回退,就用 git revert,反之用 git reset

是否需要,在遵循 git 基本原则的前提下,也有一些经验之谈。

公共分支的回退一般用 git revert

因为如果用 git reset, 后面推送到远程仓库需要强制 push 来修改历史提交记录,但是 git 的一般原则是不要破坏公共分支的历史提交记录,故公共分支上的回退一般用 git revert。还有就是,对公共分支的修改,本来就应该记录 。最后一点就是,如果用 git reset 修改了公共分支的历史提交记录,其他同事都将不得不使用 git reset --hard origin/publicBranch 命令来将远程仓库代码同步到本地,这很蛋疼,因为本地未提交的代码都会被抹除。

非公共分支的回退一般用 git reset

就我平时的开发而言,在个人的分支上回退,git reset 更合适。比如你刚提交完一次代码,突然发现里面有句注释有错别字,你想修改,这个时候就可以直接用 git reset HEAD^ 将上一次提交的代码回退到工作区,修改错别字后重新提交。这种情况下就很适合 git reset,因为没有多余的记录,并且也不需要记录,你以及你的同事都不 care "修改错别字" 这一条记录。

相关推荐
zh路西法5 分钟前
【git一键push脚本】基于Windows bat脚本的一键git提交脚本
windows·git·elasticsearch
phltxy17 分钟前
Redis 持久化机制
java·redis·git
九皇叔叔22 分钟前
Git 首次提交项目
git
长沙红胖子Qt1 小时前
关于 sourceTree桥接管理远端svn仓库出现git时区差8小时无法同步 的解决方法
git·svn·时间差·8小时
weelinking1 小时前
2026年三大主流大模型深度对比:GPT-5.5、Claude 4.6与DeepSeek V4谁更值得选择?
java·大数据·人工智能·git·python·gpt·github
爱上纯净的蓝天10 小时前
Git 入门完全指南:从安装到第一次开源贡献
git·开源
小陈同学,,10 小时前
如何切换git仓库
git
OYangxf14 小时前
Git Commit Message
运维·git
芯有所享14 小时前
【芯片设计中的版本管理:Git与SVN的实战选择指南】
经验分享·git·svn
开发者联盟league15 小时前
解决git报错 filename too long
git