Git提交修正的核心技巧:git commit --amend 的专业实践与深度解析
结论先行
git commit --amend 是用于 修正最近一次提交 的高效工具,可修改提交信息、追加遗漏文件或调整代码内容,避免冗余提交记录,保持提交历史的简洁性。适用于本地未推送的提交修复场景。
文章持续更新,可以微信搜一搜「 半个脑袋儿 」第一时间阅读
核心功能与操作
1. 修改提交信息
## 修改最近一次提交的描述(未推送时使用)
git commit --amend -m "修正后的提交信息"
- 场景:提交信息拼写错误、描述不准确时重新编辑。
2. 追加文件到最近提交
## 将漏掉的文件加入暂存区
git add 遗漏的文件名
## 合并到最近提交(保留原提交信息)
git commit --amend --no-edit
- 场景:提交后发现有文件未添加,需合并到同一提交记录。
3. 修改提交内容
## 修改代码后,将改动加入暂存区
git add 修改的文件
## 合并到最近提交(可选是否修改提交信息)
git commit --amend
- 场景:提交后发现代码存在小错误(如拼写、逻辑问题),需立即修复。
关键注意事项
- 仅限本地未推送的提交
- 若已推送至远程仓库,需用
git push -f强制覆盖,但需谨慎操作,可能影响他人协作。
- 若已推送至远程仓库,需用
- 提交历史会被重写
- 修正后的提交会生成新的 Hash ID,原有提交从历史中移除。
- 协作分支避免强制推送
- 公共分支(如
main或develop)禁止强制推送,否则可能导致团队代码混乱。
- 公共分支(如
进阶用法
- 修改提交作者信息
## 重置为当前配置的用户
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 的专业实践与深度解析的更多相关文章
- DEA使用git提交代码时,点了commit之后卡死在performing code analysis部分,或者performing code analysis结束后没有进入下一步操作。
把"Perform code analysis" 和 "Check TODO" 复选框前面的勾去掉就好了. 这个可能是因为所分析的目标文件太大了,造成一直分析不 ...
- IDEA使用git提交代码时,点了commit之后卡死在performing code analysis部分,或者performing code analysis结束后没有进入下一步操作
把"Perform code analysis" 和 "Check TODO" 复选框前面的勾去掉就好了. 这个可能是因为所分析的目标文件太大了,造成一直分析不 ...
- git提交项目常用命令及git分支的用法
1.第一步首先从git托管平台clone项目,我这里就使用idea为例: 填写git的url与存放本地目录名及项目名 2.如果你对项目进行了一些修改,就可以执行git命令,进行提交. 有两种方 ...
- git commit --amend的撤销方法
某同事执行git commit 时太兴奋,执行了 git commit --amend 慌了,不敢编辑上一个commit的description了,直接选择了wq退出,然而git毕竟强大,默认将改动合 ...
- 怎么创建一个良好的Git提交信息
译 原文:https://dev.to/chrissiemhrk/git-commit-message-5e21 提交信息是对提交之前添加和更改的文件所做的更改的简短描述. 良好的提交信息不仅对你 ...
- git提交后文件夹显示灰色无法打开的解决办法
上传完本地文件到gitee线上后发现如下情况,文件夹显示为灰色并且无法访问. xxx@xxx 的灰色文件 问题原因 : 无法点击的灰色文件夹中含有 .git 文件 即在本地初始化的仓库(使用 git ...
- 『现学现忘』Git后悔药 — 34、git commit --amend 命令
目录 1.git commit --amend 命令说明 2.使用场景 (1)场景一 (2)场景二 3.git commit --amend 命令原理 这是我们Git中的第三种后悔药. 1.git c ...
- Git——快速重命名文件和查看commit提交版本【四】
快速重命名文件 $ git mv README.md readme.md 使用git mv命令后直接commit即可,不再需要进行add或rm操作 查看版本历史 所有的参数都可以进行组合使用的,比如我 ...
- commit lint规范化团队git提交信息
一.快速提交符号angular编码规范的提交信息 1.命令行中安装commitizen: npm install -g commitizen commitizen init cz-convention ...
- Git 提交的正确姿势:Commit message 编写指南
http://www.ruanyifeng.com/blog/2016/01/commit_message_change_log.html Git 每次提交代码,都要写 Commit message( ...
随机推荐
- 解决tsc编译器版本过低问题
我们知道,tsc是TypeScript的编译器,可以将TypeScript脚本(.ts文件)编译为JavaScript脚本(.js文件).根据约定,TypeScript脚本文件使用.ts后缀名,Jav ...
- Q:LISTAGG()函数用法笔记(oracle)
.LISTAGG()函数作为普通函数使用时就是查询出来的结果列转为行 ☆LISTAGG 函数既是分析函数,也是聚合函数有两种用法:1.分析函数,如: row_number().rank().dense ...
- 同事PPT又拿奖了?偷偷用这AI工具,3步做出老板狂赞的年度报告
大家好,我是六哥,今天为大家分享一款PPT辅助神器,年底汇报必备神器!就是Napkin AI ! 这是一款超级酷的工具,它能把你写的文字一秒钟转化为各种炫酷的视觉效果,比如图表.流程图.信息图啥的.如 ...
- Linux 通过docker安装nginx,.net core sdk或运行时安装到Linux
1.Linux docker通过yum安装 https://blog.csdn.net/GMingZhou/article/details/94024453 https://qizhanming.co ...
- next.js 添加 PWA 渐进式WEB应用(service-worker) 支持
本文仅作为 next 系列文章中的一部分,其他 next 文章参考: https://blog.jijian.link/categories/nextjs/ 去 github 搜索了一把,估计是我关键 ...
- 【VMware VCF】解决 VCF 环境中组件用户密码过期问题。
由于长时间没有启动 VCF 环境,现在在启动 SDDC Manager 组件后,UI 一直处于如下图所示的"初始化"状态.当时第一直觉就认为肯定是 VCF 环境组件的用户密码过期了 ...
- CDH6.3.2下安装部署Qualitis数据质量分析的计算服务Linkis1.3.2
快速搭建Qualitis手册 一.基础软件安装 Gradle (4.6) MySQL (5.5+) JDK (1.8.0_141) Linkis(1.0.0+), 必装Spark引擎.如何安装Link ...
- PVE常用命令
1.查看集群下的节点信息 root@pve63-node172:~# pvecm nodes Membership information ---------------------- Nodeid ...
- delphi+sql数据库增加,删除,修改,查询操作
需要注意的是,open一般用于查询(select),exesql用于修改,插入,删除(update,insert,delete) 增加 with dm.DataModule1.ADOQuery1 do ...
- MySQL查询当前连接数的语句
1. 查看当前总连接数 SHOW STATUS LIKE 'Threads_connected'; 返回当前建立的连接总数 2. 查看最大连接数配置 SHOW VARIABLES LIKE 'max_ ...