git add 和git commit之后怎么撤销?

在本地执行 git addgit commit 后未推送到远程(git push),撤销操作完全安全(不影响远程 develop 分支),核心根据「是否保留代码修改」选择不同撤销方式,以下是分场景的精准命令:

前提:先查看本地提交记录(找到要回退的基准)

首先执行以下命令,确认要撤销的 commit 信息(重点看 HEAD 指向的最新提交,以及上一个干净的提交 ID):

复制代码
# 查看简洁的提交历史(--oneline 简化输出)
git log --oneline

# 输出示例(假设最近1次是错误提交):
# a1b2c3d (HEAD -> develop) feat: 错误提交的内容  # 要撤销的commit
# 987654e 上一个干净的提交(想回到这个状态)

场景 1:仅撤销 git commit(保留代码修改,回到 git add 前)

需求 :不想保留这次 commit,但代码修改还要(比如提交信息写错、漏改文件),撤销 commit 且取消 git add(修改回到工作区)。

复制代码
# 方式1:默认方式(--mixed,推荐,无需加参数)
git reset 987654e  # 987654e 是「上一个干净的提交ID」(示例)

# 方式2:显式指定 --mixed(效果和上面完全一致,可选)
git reset --mixed 987654e

✅ 效果:

  • 撤销本次 git commit,本地提交记录回到 987654e
  • 撤销本次 git add,所有修改回到「未暂存」状态(工作区);
  • 代码修改完全保留,可重新编辑后再次 git add + git commit

场景 2:撤销 git commit 且保留 git add(仅改提交信息)

需求 :只是提交信息写错,想保留 git add 的状态(修改仍在暂存区),仅撤销 commit 重新提交。

复制代码
git reset --soft 987654e  # 987654e 是上一个干净的提交ID

✅ 效果:

  • 撤销本次 git commit,但 git add 状态保留(修改仍在暂存区);
  • 直接执行 git commit -m "修正后的提交信息" 即可重新提交,无需再次 git add

场景 3:彻底撤销(放弃本次所有代码修改 + 撤销 commit)

需求 :本次修改完全错误,想回到上一个干净的提交,且放弃所有本地修改。⚠️ 注意:此操作会永久删除本次代码修改,谨慎使用!

复制代码
git reset --hard 987654e  # 987654e 是上一个干净的提交ID

✅ 效果:

  • 撤销本次 git commit + 撤销 git add
  • 本地代码强制回滚到 987654e 状态,本次所有修改被删除;
  • 执行后可通过 git status 确认工作区是「干净的」。

补充:仅撤销 git add(未执行 git commit

若只执行了 git add 但还没 git commit,想取消暂存(回到工作区):

复制代码
# 撤销所有已add的文件
git reset

# 撤销指定已add的文件(精准撤销)
git reset 路径/到/文件.cpp

关键说明(避坑)

  1. 所有操作仅针对本地 :未执行 git push 前,远程 develop 分支完全不受影响,放心操作;
  2. 提交 ID 简化写法:无需复制完整的 40 位 ID,前 6-8 位即可(如 987654e);
  3. 恢复误操作:若用 git reset --hard 误删代码,可通过 git reflog 找回(执行 git reflog 找到误删的 commit ID,再 git reset --hard 该ID 即可恢复)。

操作验证(撤销后确认状态)

执行撤销命令后,用以下命令确认是否达到预期:

复制代码
git status
# 预期输出(场景1/2):显示「未暂存的修改」(代码保留,无commit);
# 预期输出(场景3):显示「工作区干净」(无修改、无commit)。
相关推荐
先跑起来再说2 小时前
Git 入门到实战:一篇搞懂安装、命令、远程仓库与 IDEA 集成
ide·git·后端·elasticsearch·golang·intellij-idea
承渊政道5 小时前
Linux系统学习【Linux系统的进度条实现、版本控制器git和调试器gdb介绍】
linux·开发语言·笔记·git·学习·gitee
Doro再努力5 小时前
【Linux操作系统12】Git版本控制与GDB调试:从入门到实践
linux·运维·服务器·git·vim
摇滚侠8 小时前
MAC IDEA GIT 提交区显示了几个不存在的目录
git·idea
城东8 小时前
Git使用[远程仓库远端的head比本地和提交的head旧,其他人拉不到最新代码]
git·head·远程仓库远端·比本地和提交的head旧·其他人拉不到最新代码
何中应17 小时前
使用SSH地址拉取远程仓库代码报下面的错误
git
何中应17 小时前
Git本地仓库命令补充
git
sun00770019 小时前
执行repo sync -c -d -j4以后,提交未git push的代码看不到了。要怎么恢复?
git
胖虎121 小时前
Git 一个本地仓库同时推送到两个远程仓库(详细教程)
git·多远程仓库·双远程仓库·git双远程·git备份
春日见1 天前
如何创建一个PR
运维·开发语言·windows·git·docker·容器