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)。
相关推荐
CoderJia程序员甲2 小时前
GitHub 热榜项目 - 日榜(2025-12-11)
git·ai·开源·llm·github
winner88813 小时前
告别“这个分支是干啥的?”:Git分支层级命名实战
git·git push -u·分支关联·层级分支命名
真上帝的左手3 小时前
3. 代码管理-Git实战
git
lin62534226 小时前
Android仿小米视频播放器的缩放滚轮
android·git·github
互亿无线明明6 小时前
在 Go 项目中集成国际短信能力:从接口调试到生产环境的最佳实践
开发语言·windows·git·后端·golang·pycharm·eclipse
world_in_world6 小时前
git常见场景命令
git
码上成长7 小时前
长耗时接口异步改造总结
前端·git·后端
Elieal7 小时前
Git 面试题全面汇总
git
rchmin7 小时前
Git撤销命令revert与reset区别
git