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

相关推荐
洋仔3 小时前
Git 底层原理系列 · 第8讲 — HEAD 与 detached HEAD
git·开源
洋仔3 小时前
Git 底层原理系列 · 第4讲 — `git add` 与 `git commit` 底层做了什么
git·开源
猫咪老师QAQ5 小时前
基于 Git Flow 的团队协作与发布流程实践
git
caicai_xiaobai5 小时前
分享一个访问Git Hub的好方法
git
Joy T6 小时前
【Web3】跨链资金池与消息路由:CCIP 智能合约集成实战与权限收束
git·web3·node·智能合约·hardhat
難釋懷7 小时前
Nginx虚拟主机
git·nginx·github
moMo7 小时前
# Git 入门—代码仓库的使用
git·github
一路向北he8 小时前
git仓库创建新分支,上传文件
git
半个落月11 小时前
从零开始理解 Git 核心操作:告别单机开发的“原始时代”
git
东风破_11 小时前
别学 Git 命令了,先搞懂这仨区域:工作区→暂存区→仓库
git