在本地执行 git add 和 git 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
关键说明(避坑)
- 所有操作仅针对本地 :未执行
git push前,远程develop分支完全不受影响,放心操作; - 提交 ID 简化写法:无需复制完整的 40 位 ID,前 6-8 位即可(如
987654e); - 恢复误操作:若用
git reset --hard误删代码,可通过git reflog找回(执行git reflog找到误删的 commit ID,再git reset --hard 该ID即可恢复)。
操作验证(撤销后确认状态)
执行撤销命令后,用以下命令确认是否达到预期:
git status
# 预期输出(场景1/2):显示「未暂存的修改」(代码保留,无commit);
# 预期输出(场景3):显示「工作区干净」(无修改、无commit)。