当前位置: 首页
编程语言
Git revert撤销提交的完整操作步骤教程

Git revert撤销提交的完整操作步骤教程

热心网友 时间:2026-06-14
转载

一、git revert核心概念

代码写错了,想回到过去?如果你是单人开发,git reset或许还能任性一把;但一旦代码已经推送到远程、多人在同一个分支上协作,这时直接修改历史就像在交规里逆行——迟早要出事。而git revert就是那个让你安全掉头、又不破坏交规的操作。

使用Git实现revert的完整操作步骤

它不会删除或改写任何已有的提交记录,而是生成一个全新的提交,这个新提交的内容恰好“抵消”了目标提交的所有改动。这样一来,历史记录完整保留,团队里每个人都能看到“何时、因何原因撤销了哪段代码”。适用场景很清晰:

  • 代码已推送远程仓库(绝对不能修改公共历史)
  • 需要保留回退痕迹,方便日后审计追溯
  • 多人协作中回退代码,不影响其他人已有的工作成果

二、git revert完整操作步骤(以你的机械臂场景为例)

步骤 1:查看提交历史,找到要撤销的 Commit ID

先通过日志定位目标提交——记住要找的是那个提交的哈希值(通常前7位就够用)。

# 简洁模式,一眼看清提交链git log --oneline# 详情模式,包含作者、时间、完整IDgit log

假设输出长这样(--oneline模式):

a87b9c0 (HEAD -> main) 优化机械臂J3角度判断逻辑5d6e7f8 初始化机械臂笛卡尔坐标获取9b8a7s6 新增手型切换基础逻辑

现在要撤销的是a87b9c0这个“优化机械臂J3角度判断”的提交。

步骤 2:执行git revert撤销目标提交

基础用法(撤销单个提交)

# 撤销指定提交,Git会自动打开默认编辑器让你填写提交信息git revert a87b9c0

执行后Git会生成一个默认的revert提交信息,比如Revert "优化机械臂J3角度判断逻辑"。你可以照之前约定的规范修改——补充撤销原因、关联工单编号等。修改完成后的操作和vim一样:按Esc退出编辑,输入:wq保存退出。

快速提交(无需打开编辑器)

如果不想手动编辑,直接加-m参数指定完整提交信息:

git revert a87b9c0 -m "revert: 撤销机械臂J3角度判断逻辑的修改 (#123)原因:J3角度范围判断覆盖不全,导致手型误判撤销的提交ID:a87b9c0"

步骤 3:处理 revert 过程中的冲突(常见场景)

如果目标提交修改的代码段和当前工作区的代码有冲突——比如你在撤销前又改了同一行——Git会停下来提示冲突。这时候别慌:

# 查看哪些文件冲突了git status

冲突文件会被标记为both modified。打开文件,你会看到类似这样的标记:

<<<<<<< HEAD# 当前分支的代码elbow_x = shoulder_x + 10  # 现有逻辑=======# 被撤销提交的代码elbow_x = shoulder_x + 5   # 要撤销的逻辑>>>>>>> a87b9c0 (优化机械臂J3角度判断逻辑)

手动清理:保留你需要的正确代码,删掉冲突标记(<<<<<<<=======>>>>>>>这三行)。然后标记文件为已解决并完成revert:

git add 冲突文件名.pygit revert --continue

如果中途发现不对劲想放弃这次revert,执行:

git revert --abort

步骤 4:推送 revert 提交到远程仓库

撤销完成后,新生成的revert提交还在本地,需要推送到远程(比如main分支):

git push origin main

三、进阶场景:撤销多个提交/合并提交

1. 撤销连续的多个提交

如果要撤销a87b9c09b8a7s6之间所有提交(注意顺序:旧在前,新在后):

git revert 9b8a7s6..a87b9c0

2. 撤销合并提交(需指定父节点)

如果要撤销的是一个合并分支的提交,需要加-m参数指定父节点——通常1表示主分支:

git revert 合并提交ID -m 1

四、git revert vs git reset(新手必区分)

特性git revertgit reset
历史记录保留所有提交(新增revert提交)删除指定提交后的所有记录
适用场景已推送的远程代码本地未推送的代码
团队协作安全(不影响他人)危险(会覆盖远程历史)
可追溯性强(能看到撤销过程)弱(历史记录被删除)

总结

  1. git revert 是安全的回退方式,核心是生成新提交抵消旧修改,适合已推送的代码。
  2. 核心操作流程:查看Commit ID → 执行git revert → 处理冲突(如有)→ 推送远程
  3. 提交信息要包含「操作类型+撤销原因+目标Commit ID」,便于团队追溯。
来源:https://www.jb51.net/program/3576249nq.htm

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
Git删除远程分支与本地分支的详细操作步骤

Git删除远程分支与本地分支的详细操作步骤

删除远程分支用`gitpushorigin--delete`,本地分支根据是否合并选`gitbranch-d`安全删除或`-D`强制删除。现代编辑器也提供可视化删除。清理前需确认分支状态,避免误删重要更改。

时间:2026-06-14 06:52
Git合并后回退操作完整指南与步骤详解

Git合并后回退操作完整指南与步骤详解

在Git合并后遇问题时,可使用三种方案回退:完成合并并提交;放弃合并并回退到合并前状态;完全重置到远程状态。关键命令包括gitmerge--abort、gitreset--hard和gitreflog。建议养成gitpull前先gitfetch、使用--no-commit等习惯,必要时启用rebase策略。

时间:2026-06-14 06:52
一文快速掌握Git暂存与stash功能全面指南

一文快速掌握Git暂存与stash功能全面指南

Git暂存区通过gitadd添加修改、gitrestore--staged取消暂存。stash临时保存未提交修改使工作区变干净,常用命令有gitstashpush-m添加备注、stashlist查看记录、stashpop恢复并删除、stashapply恢复不删除、stashdrop clear删除记录。默认不储藏未追踪文件,需加-u参数;建议同分支储藏同分支

时间:2026-06-14 06:52
Git忽略大小写重命名文件的解决方法

Git忽略大小写重命名文件的解决方法

Git默认忽略文件名大小写,需设置`core ignorecasefalse`开启大小写敏感。当修改文件名大小写后,先执行`gitrm--cached`删除旧文件的暂存记录,再执行`gitadd`添加新文件,最后提交即可完成重命名。这样能避免远程仓库中出现重复文件,确保大小写变更被正确追踪。

时间:2026-06-14 06:52
微信小程序input只读属性readonly失效原因

微信小程序input只读属性readonly失效原因

微信小程序中input的readonly属性仅限制编辑,仍可聚焦并触发事件,无法完全禁止用户交互。建议改用disabled属性彻底禁用、阻止事件传播或设置CSS的pointer-events:none解决。纯展示场景推荐直接使用view组件,并根据业务场景选择合适方案。

时间:2026-06-14 06:52
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜