天准星智携手BlackBerry QNX,共筑智能驾驶与泛机器人产业新未来
2026/5/7 19:15:35
git commit --amend是 Git 中用于修改最后一次提交的核心命令,常用于修正提交信息、补充遗漏文件,或合并暂存区修改到上一次提交(避免无意义的“修正xxx”提交)。
修改最近一次的提交(包括提交信息、提交内容),本质是用新的提交替换旧的提交(会改变提交哈希值),因此已推送到远程的提交不建议 amend(会导致本地与远程历史不一致,需强制推送,协作场景慎用)。
比如提交时写错备注(如把fix: 修复登录bug写成fix: 修复登路bug),执行:
gitcommit --amendgitcommit --amend -m"正确的提交信息:fix: 修复登录bug"比如提交后发现漏加了一个文件/修改,步骤:
gitadd遗漏的文件路径# 比如 git add src/login.jsgitcommit --amend --no-edit# --no-edit 表示不修改提交信息比如提交后发现代码写错,想直接修正并覆盖上一次提交:
gitadd已修改的文件路径gitcommit --amend# 如需改信息则编辑,不改则加 --no-edit| 参数 | 作用 |
|---|---|
-m "信息" | 直接指定新的提交信息,无需打开编辑器 |
--no-edit | 保留原提交信息,仅修改提交内容(文件) |
--author | 修改提交的作者信息(如git commit --amend --author="张三 <zhangsan@xxx.com>") |
--date | 修改提交的时间(如git commit --amend --date="2025-12-12 10:00:00") |
git push),再amend会导致本地历史与远程不一致,此时强制推送需谨慎:gitpush -f# 强制推送,协作场景下会覆盖远程历史,需提前告知团队成员git reflog找回旧提交:gitreflog# 找到 amend 前的提交哈希(如 abc123)gitreset --hard abc123# 恢复到旧提交git revert撤销后重新提交。# 1. 第一次提交(信息错误+漏文件)gitaddsrc/xxx.jsgitcommit -m"feat: 新增登录功能"# 2. 发现漏加 src/utils.js,且提交信息写错gitaddsrc/utils.js# 补充文件到暂存区# 3. amend 修改:修正信息 + 合并漏加的文件gitcommit --amend -m"feat: 完善登录功能(补充工具函数)"# 4. 若未推送过,正常推送即可;若已推送(谨慎!)gitpush -f origin 分支名