结论先行

git commit --amend 是用于 修正最近一次提交 的高效工具,可修改提交信息、追加遗漏文件或调整代码内容,避免冗余提交记录,保持提交历史的简洁性。适用于本地未推送的提交修复场景。

文章持续更新,可以微信搜一搜「 半个脑袋儿 」第一时间阅读


核心功能与操作

1. 修改提交信息
## 修改最近一次提交的描述(未推送时使用)
git commit --amend -m "修正后的提交信息"
  • 场景:提交信息拼写错误、描述不准确时重新编辑。

2. 追加文件到最近提交
## 将漏掉的文件加入暂存区
git add 遗漏的文件名 ## 合并到最近提交(保留原提交信息)
git commit --amend --no-edit
  • 场景:提交后发现有文件未添加,需合并到同一提交记录。

3. 修改提交内容
## 修改代码后,将改动加入暂存区
git add 修改的文件 ## 合并到最近提交(可选是否修改提交信息)
git commit --amend
  • 场景:提交后发现代码存在小错误(如拼写、逻辑问题),需立即修复。

关键注意事项

  1. 仅限本地未推送的提交

    • 若已推送至远程仓库,需用 git push -f 强制覆盖,但需谨慎操作,可能影响他人协作。
  2. 提交历史会被重写
    • 修正后的提交会生成新的 Hash ID,原有提交从历史中移除。
  3. 协作分支避免强制推送
    • 公共分支(如 maindevelop)禁止强制推送,否则可能导致团队代码混乱。

进阶用法

  • 修改提交作者信息
    ## 重置为当前配置的用户
    git commit --amend --reset-author ## 手动指定新作者
    git commit --amend --author="Author Name <email@example.com>"
  • 保留原提交时间戳
    ## 使用原提交时间(需获取原提交时间并替换)
    git commit --amend --date="原提交时间"

最佳实践

  • 本地未推送的提交:优先使用 --amend,减少无意义的提交记录。
  • 已推送的提交:确认无他人依赖后,再执行 git push -f,并通知团队。
  • 复杂历史修改:若需修改更早的提交,使用 git rebase -i 进行交互式变基。

通过 git commit --amend,让每一次提交都精准无误,维护清晰高效的代码历史!

Git提交修正的核心技巧:git commit --amend 的专业实践与深度解析的更多相关文章

  1. DEA使用git提交代码时,点了commit之后卡死在performing code analysis部分,或者performing code analysis结束后没有进入下一步操作。

    把"Perform code analysis" 和 "Check TODO" 复选框前面的勾去掉就好了. 这个可能是因为所分析的目标文件太大了,造成一直分析不 ...

  2. IDEA使用git提交代码时,点了commit之后卡死在performing code analysis部分,或者performing code analysis结束后没有进入下一步操作

    把"Perform code analysis" 和 "Check TODO" 复选框前面的勾去掉就好了. 这个可能是因为所分析的目标文件太大了,造成一直分析不 ...

  3. git提交项目常用命令及git分支的用法

    1.第一步首先从git托管平台clone项目,我这里就使用idea为例: 填写git的url与存放本地目录名及项目名     2.如果你对项目进行了一些修改,就可以执行git命令,进行提交. 有两种方 ...

  4. git commit --amend的撤销方法

    某同事执行git commit 时太兴奋,执行了 git commit --amend 慌了,不敢编辑上一个commit的description了,直接选择了wq退出,然而git毕竟强大,默认将改动合 ...

  5. 怎么创建一个良好的Git提交信息

    译   原文:https://dev.to/chrissiemhrk/git-commit-message-5e21 提交信息是对提交之前添加和更改的文件所做的更改的简短描述. 良好的提交信息不仅对你 ...

  6. git提交后文件夹显示灰色无法打开的解决办法

    上传完本地文件到gitee线上后发现如下情况,文件夹显示为灰色并且无法访问. xxx@xxx 的灰色文件 问题原因 : 无法点击的灰色文件夹中含有 .git 文件 即在本地初始化的仓库(使用 git ...

  7. 『现学现忘』Git后悔药 — 34、git commit --amend 命令

    目录 1.git commit --amend 命令说明 2.使用场景 (1)场景一 (2)场景二 3.git commit --amend 命令原理 这是我们Git中的第三种后悔药. 1.git c ...

  8. Git——快速重命名文件和查看commit提交版本【四】

    快速重命名文件 $ git mv README.md readme.md 使用git mv命令后直接commit即可,不再需要进行add或rm操作 查看版本历史 所有的参数都可以进行组合使用的,比如我 ...

  9. commit lint规范化团队git提交信息

    一.快速提交符号angular编码规范的提交信息 1.命令行中安装commitizen: npm install -g commitizen commitizen init cz-convention ...

  10. Git 提交的正确姿势:Commit message 编写指南

    http://www.ruanyifeng.com/blog/2016/01/commit_message_change_log.html Git 每次提交代码,都要写 Commit message( ...

随机推荐

  1. ceph 16.2.15(Pacific)编译

    目录 获取ceph源码 编译 拉取submodule网络问题 安装依赖 do_cmake.sh 编译 vstart启动 问题 编译dashboard 安装nodejs 方法一 下载编译好的源码包 方法 ...

  2. 单机stome安装

    先安装zookeeper,参考本文件夹下安装文档 启动zookeeper 1.解压stome /opt/Server目录下 tar -zxf apache-storm-1.1.0.tar.gz 2.修 ...

  3. [国家集训队] Tree2 题解

    加边删边 \(LCT\),标记下放同 \(luogu\) 线段树 \(2\) 一题. 时间复杂度 \(O(n\log n)\),第一次交的时候我维护 \(sum\) 不维护 \(sz\ WA\) 完了 ...

  4. 从SQL Server迁移到Mysql Mysql导入SQL Server的数据库

    mysql怎么导入 SQl Server的数据库, SQL Server导出的SQL文件Mysql无法识别 需要用到的软件 Navicat mysql workbanch SQL Server man ...

  5. webgpu学习问题,遇到了create graphics pipeline state failed错误

    在学习webgpu并渲染图像时发生create graphics pipeline state failed with E_INVALIDARG (0x80070057)错误,图像无法成功渲染. ht ...

  6. 雷电4扩展坞HDMI显示器无法睡眠问题

    背景: 最近使用Dell的雷电4扩展坞WD22TB4,感觉很爽,取电脑时,不用再拔显示器.鼠标.键盘,直接把雷电4接口拔出即可. 后来通过windows update升级了intel显卡驱动后,发现电 ...

  7. Typecho获取当前页面加载完成速度时间

    判断当前页面加载是否快速,通常是直接在浏览器中访问网站,看自己的直观感受是否快速.而客观的方法则是计算具体的页面加载时间并显示出来给看. 1.在当前主题的functions.php文件添加下面的代码: ...

  8. 事务中无法切换数据源?DataSourceSwitchInvoker:轻松实现多数据源切换执行工具类

    背景: 在有标注为@Transactional的类或公共方法中(传播特性,如:NOT_SUPPORTED.SUPPORTS.REQUIRED[默认值].REQUIRES_NEW)执行数据源切换可能不成 ...

  9. c++经典卡常

    1.展开函数 如下代码: void lowbit(int x) { return x&(-x); } signed main() { cout << lowbit(12345); ...

  10. Easyexcel(3-文件导出)

    响应头设置 通过设置文件导出的响应头,可以自定义文件导出的名字信息等 //编码格式为UTF-8 response.setCharacterEncoding("UTF-8"); // ...