回退用 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 "修改错别字" 这一条记录。

相关推荐
点亮~黑夜11 小时前
git详细使用教程
大数据·git·elasticsearch
bin915311 小时前
当AI化身Git管家:初级C++开发者的版本控制焦虑与创意逆袭——老码农的幽默生存指南
c++·人工智能·git·工具·ai工具
hello1114-11 小时前
Git 学习打卡Day1-基础、高级、远程仓库初步
git·学习·github
鸽鸽程序猿11 小时前
【Git】分支管理
git
青衫码上行11 小时前
分布式版本控制系统Git的安装和使用
分布式·git·svn
.豆鲨包12 小时前
【Git】Git的配置与使用(非常详细)
git·github
胖咕噜的稞达鸭12 小时前
基础IO 文件在内核中是怎么被管理的 重定向的含义 在自定义shell中加入重定向
linux·c++·git·腾讯云·visual studio·csdn开发云
小生不才yz12 小时前
(二)日常工作流 - git grep 命令的使用
git
摇滚侠12 小时前
零基础小白自学 Git_Github 教程,Idea 中使用 Git 进阶,笔记17
笔记·git·github
Violet_YSWY12 小时前
git清理缓存
git·elasticsearch·缓存