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)。
相关推荐
vibecoding日记2 天前
为什么我就想要「线性历史 + Signed Commits」,GitHub 却把我当猴耍 🤬🎙️
git·编程工具
程序员小崔日记2 天前
如何将代码轻松上传到 Gitee?Git 使用全攻略!
git·gitee·上传
Bigger3 天前
为什么你的 Git 提交需要签名?—— Git Commit Signing 完全指南
git·开源·github
DianSan_ERP4 天前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet
红豆子不相思4 天前
Tomcat 环境搭建与集群实战
服务器·git·tomcat
杰哥技术分享4 天前
Git 仓库迁移技术文档:从 CODING.net 迁移至腾讯云 CNB
git
梅孔立4 天前
Ansible 100 台服务器一键管控实战 进阶版
服务器·git·ansible
qq_426003965 天前
git切换当前分支到远程分支
git
ON10N5 天前
100% 纯 Vibe Coding,我是怎么用 AI 撸出一个 VS Code 插件的
git·ai编程·visual studio code