git commit --amend 之后,想要修改为git commit , 如何处理?

执行 git commit --amend 后,如果想撤销这次 amend 操作,恢复到它之前的那个 commit 状态,你需要使用 git refloggit reset 命令。

核心思路

git commit --amend 并不是真的"修改"了上一个提交,而是创建了一个全新的提交 来替换掉它。不过,Git 并不会立即丢弃那个被替换掉的旧提交,它只是暂时"隐藏"了起来。我们可以通过 git reflog 找到这个旧提交,然后将分支指回它。

步骤一:查找历史记录 (git reflog)

首先,在你的终端里运行 git reflog 命令。这个命令会显示 HEAD 指针最近的所有移动记录,包括每一次 commit、amend、reset 等操作。

你会看到类似下面的输出:

bash 复制代码
a1b2c3d HEAD@{0}: commit (amend): Your new amended commit message
f9e8d7c HEAD@{1}: commit: Your original commit message
... (更早的记录)

分析这个输出:

  • HEAD@{0} 是你当前所在的位置,也就是 git commit --amend 之后创建的新提交 (a1b2c3d)。
  • HEAD@{1} 就是你执行 amend 操作之前 的那个提交,也就是你想要恢复到的原始提交 (f9e8d7c)。

你的目标就是恢复到 HEAD@{1} 这个状态。

步骤二:重置分支状态 (git reset)

找到了目标提交后,使用 git reset 命令将当前分支的 HEAD 指针移回那个原始提交.

如果你只是想撤销 amend 这个提交动作,但又希望保留 你在 amend 时所做的代码修改,可以使用 --soft--mixed 参数。

  • 使用 --soft

    perl 复制代码
    bash
    git reset --soft HEAD@{1}

    这会撤销 amend 提交,并将 amend 中所做的所有代码改动放回到暂存区(Staged) 。你可以重新 git commit

  • 使用 --mixed (默认选项):

    perl 复制代码
    bash
    git reset --mixed HEAD@{1}
    # 或者 git reset HEAD@{1}

    这会撤销 amend 提交,并将 amend 中所做的所有代码改动放回到工作区(Working Directory) ,你需要重新 git addgit commit

相关推荐
老友記1 天前
git cherry-pick使用
git
练习时长一年1 天前
git常用命令总结
大数据·git·elasticsearch
hadage2331 天前
--- git 的一些使用 ---
开发语言·git·python
4***V2021 天前
GitLab Pages配置
git·gitlab·github
CelineCoding1 天前
git 处理异常操作
git
E***q5391 天前
Git版本控制常见问题
git
sulikey2 天前
从入门到精通:如何自己编写高质量的 .gitignore(面向工程实践)
git·gitee·编辑器·gitlab·github·gitignore·gitattributes
青靴2 天前
轻量级 CI/CD:Git Hooks 自动部署 Node.js 应用(CICD-demo)
git·ci/cd·node.js
哟哟耶耶2 天前
git-git cherry-pick(从分支挑选特定提交-哈希值)更改应用到当前分支
git
无限进步_2 天前
C语言动态内存管理:掌握malloc、calloc、realloc和free的实战应用
c语言·开发语言·c++·git·算法·github·visual studio