news 2026/7/1 16:36:24

reset和revert最佳实践

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
reset和revert最佳实践

git revert = 新增一个“反向提交”,历史不变
git reset = 移动 HEAD / 分支指针,历史被重写


一、git revert:不修改已有 Git 历史

1️⃣ revert 做了什么?

gitrevert<commit>

它的本质是:

  • 生成一个新的 commit
  • 这个新 commit 的内容 = 把指定 commit 的修改「反向再做一遍」

📌原来的 commit 还在,历史是线性的


2️⃣ revert 之后的 git log 长什么样?

假设原历史:

A --- B --- C --- D (HEAD)

执行:

gitrevert C

结果:

A --- B --- C --- D --- E (HEAD)

其中:

  • C:原提交(还在)
  • E:revert C 的提交(内容上抵消 C)

📌Git 记录没有被删,没有被移动,只是多了一条提交


3️⃣ revert 的特点总结

安全

  • 适合已经 push 到远端的分支
  • 不影响其他人

历史会“变长”

  • 会看到「提交 + revert 提交」

📌 面试一句话:

revert 是“用新的提交修正旧的提交”,不破坏历史


二、git reset:直接改 Git 历史(移动指针)

reset 的核心动作只有一个:

把 HEAD / 当前分支指针,指向一个旧的 commit


1️⃣ reset 的三种模式(重点)

gitreset --softgitreset --mixed(默认)gitreset --hard

不管哪种

提交历史都会被改(HEAD 回退)


三、git reset 执行后,git 记录长什么样?

原始提交历史

A --- B --- C --- D (HEAD)

执行:

gitreset --hard B

reset 之后:

A --- B (HEAD)

📌C、D 在当前分支历史中消失了

⚠️ 但注意一句非常关键的点:

C、D 并不是立刻被删除,只是“不可达”了

只要还没被 GC(垃圾回收),还能用git reflog找回。


四、reset 三种模式对「工作区 & 暂存区」的影响

1️⃣ --soft(只改 HEAD)

gitreset --soft B

结果:

  • 提交历史:❌ 被改(C、D 消失)
  • 暂存区:✅ 保留
  • 工作区:✅ 保留

📌 等价于:

“撤回提交,但改动还在,且已经 add 过了”


2️⃣ --mixed(默认)

gitreset B

结果:

  • 提交历史:❌ 被改
  • 暂存区:❌ 清空
  • 工作区:✅ 保留

📌 等价于:

“撤回提交 + 取消 add”


3️⃣ --hard(最危险)

gitreset --hard B

结果:

  • 提交历史:❌ 被改
  • 暂存区:❌ 清空
  • 工作区:❌ 清空

⚠️代码直接没了


五、revert vs reset 终极对比表(面试版)

对比点git revertgit reset
是否修改已有提交历史❌ 不修改✅ 修改
是否生成新 commit✅ 是❌ 否
提交记录是否“变短”❌ 不会✅ 会
是否安全用于已 push 分支✅ 安全❌ 危险
适合场景回滚线上/公共分支本地整理提交

六、真实工程中的使用建议

✅ 已 push / 多人协作分支(main、develop)

只能用 revert

gitrevert<commit>

✅ 本地分支 / 还没 push

reset 非常好用

gitreset --soft HEAD~1

用于:

  • 合并提交
  • 修改 commit message
  • 整理提交历史
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/1 14:07:35

基于java + vue社团管理系统(源码+数据库+文档)

社团管理 目录 基于springboot vue个人记账系统 一、前言 二、系统功能演示 三、技术选型 四、其他项目参考 五、代码参考 六、测试参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 基于ssm vue社团管理系统 一、前言 博主介绍&#xff1a;✌️大厂码农|…

作者头像 李华
网站建设 2026/7/1 14:07:42

污染物环境行为的“逸度”密码:模型理论与高级应用

随着污染物在各种环境中的迁移和转化&#xff0c;多介质污染物模型日益受到关注。在各类多介质模型中&#xff0c;基于逸度概念的逸度模型由于运用范围广&#xff0c;建模数据要求较低而广受欢迎。 专题一&#xff1a;基本理论 1.逸度的定义 2.逸度模型的基本原理 …

作者头像 李华
网站建设 2026/7/1 14:07:42

慎选敏捷开发协作工具!忽视私有化,企业数据随时归零

一、敏捷开发是什么&#xff1f; 敏捷开发是一种以人为核心、遵循迭代式与循序渐进原则的软件开发方法论&#xff0c;核心目标是通过快速响应需求变化、紧密协作交付可用产品&#xff0c;适配当前易变、不确定的商业环境。敏捷开发的四大核心价值观&#xff1a;个体和互动重于…

作者头像 李华
网站建设 2026/7/1 14:07:41

AI助教系统:你的24小时智能学习伙伴

在今天的课堂和在线学习平台中&#xff0c;一个新“老师”正悄然登场——它不睡觉、不休息&#xff0c;还能随时回答你的问题&#xff0c;这就是AI助教系统。听起来很酷&#xff1f;其实它的背后&#xff0c;是一整套人工智能技术的巧妙整合。 那么&#xff0c;AI助教到底是什么…

作者头像 李华