不小心执行了 git revert,如何恢复到被撤销前的状态

下面是AI的回答,但是我亲自试验过可以正常执行

别慌!你是不小心执行了 git revert(也就是生成了这个 "撤销提交"),想恢复到被撤销前的状态,分两种情况(核心是把 "撤销操作本身再撤销掉"),一步步来:

第一步:先确认现状(避免操作错)

先打开终端 / 命令行,进入你的代码文件夹,执行:

复制代码
git log --oneline

会看到类似这样的记录(最新的在最上面):

复制代码
abc1234 (HEAD) Revert "之前的提交说明"  # 这是你不小心生成的撤销提交
f405d46 之前的提交说明                  # 这是被撤销的那个原提交
xxxxxxx 更早的提交

记住最上面那个 "撤销提交" 的哈希(比如 abc1234),接下来二选一操作:


情况 1:还没把这个撤销提交推到远程(比如只在本地点错了)

最简单,直接 "回退" 到撤销前的版本:

复制代码
# 用 HEAD^ 表示"上一个版本",也就是撤销操作之前的状态
git reset --hard HEAD^

执行完这句,你的代码就回到被撤销前的样子了,那个不小心的撤销提交也会被删掉。

情况 2:已经把撤销提交推到远程(比如点错后还 git push 了)

不能用 reset(会改远程历史,影响其他人),而是再做一次 revert,把 "撤销操作" 本身撤销:

复制代码
# 把 abc1234 换成你刚才看到的"撤销提交"的哈希
git revert abc1234

执行后会弹出提交说明窗口(直接保存退出就行),然后推到远程:

复制代码
git push

这样远程代码也会恢复到被撤销前的状态,且保留完整的操作痕迹,不会出问题。


验证是否恢复成功

操作完再执行 git log --oneline,看代码里被撤销的内容(比如你之前改的代码、加的文件)是不是回来了,确认没问题就搞定了。

如果看不懂命令行,也可以用 Git 图形化工具(比如 SourceTree、VSCode 自带的 Git):

  1. 找到那个 "Revert" 开头的提交;
  2. 右键选择 "Revert Commit"(再撤销一次),确认后推送到远程就行。

核心逻辑:你不小心做了 "撤销 A",现在要么删掉 "撤销 A" 的记录(本地没推送时),要么再做 "撤销 B" 抵消 "撤销 A"(已推送时),最终回到 A 提交生效的状态。

相关推荐
知识即是力量ol36 分钟前
Git 快速入门 (实习生视角)
git·gitee·github
Dontla1 小时前
Git撤销上一次提交(撤销提交,Git回退提交)git reset、git revert
git
wdfk_prog1 小时前
解决 `git cherry-pick` 引入大量新文件的问题
大数据·git·elasticsearch
fu的博客4 小时前
Git从删库到跑路
git·gitee·github
要加油哦~4 小时前
git 报错 | husky - pre-commit hook exited with code 1 解决
git
知识即是力量ol4 小时前
Git 实战指南:从分支管理到冲突解决
git·github·源代码管理
weixin_4624462317 小时前
Git 本地忽略 application-dev.yml 的最佳实践:不提交 .gitignore,不影响团队协作!
git
无限进步_1 天前
面试题 02.02. 返回倒数第 k 个节点 - 题解与详细分析
c语言·开发语言·数据结构·git·链表·github·visual studio
2401_859049081 天前
git submodule update --init --recursive无法拉取解决
前端·chrome·git
是店小二呀1 天前
Git 深度学习笔记:从初始化到核心操作机制解析
笔记·git