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( ...
随机推荐
- ceph 16.2.15(Pacific)编译
目录 获取ceph源码 编译 拉取submodule网络问题 安装依赖 do_cmake.sh 编译 vstart启动 问题 编译dashboard 安装nodejs 方法一 下载编译好的源码包 方法 ...
- 单机stome安装
先安装zookeeper,参考本文件夹下安装文档 启动zookeeper 1.解压stome /opt/Server目录下 tar -zxf apache-storm-1.1.0.tar.gz 2.修 ...
- [国家集训队] Tree2 题解
加边删边 \(LCT\),标记下放同 \(luogu\) 线段树 \(2\) 一题. 时间复杂度 \(O(n\log n)\),第一次交的时候我维护 \(sum\) 不维护 \(sz\ WA\) 完了 ...
- 从SQL Server迁移到Mysql Mysql导入SQL Server的数据库
mysql怎么导入 SQl Server的数据库, SQL Server导出的SQL文件Mysql无法识别 需要用到的软件 Navicat mysql workbanch SQL Server man ...
- webgpu学习问题,遇到了create graphics pipeline state failed错误
在学习webgpu并渲染图像时发生create graphics pipeline state failed with E_INVALIDARG (0x80070057)错误,图像无法成功渲染. ht ...
- 雷电4扩展坞HDMI显示器无法睡眠问题
背景: 最近使用Dell的雷电4扩展坞WD22TB4,感觉很爽,取电脑时,不用再拔显示器.鼠标.键盘,直接把雷电4接口拔出即可. 后来通过windows update升级了intel显卡驱动后,发现电 ...
- Typecho获取当前页面加载完成速度时间
判断当前页面加载是否快速,通常是直接在浏览器中访问网站,看自己的直观感受是否快速.而客观的方法则是计算具体的页面加载时间并显示出来给看. 1.在当前主题的functions.php文件添加下面的代码: ...
- 事务中无法切换数据源?DataSourceSwitchInvoker:轻松实现多数据源切换执行工具类
背景: 在有标注为@Transactional的类或公共方法中(传播特性,如:NOT_SUPPORTED.SUPPORTS.REQUIRED[默认值].REQUIRES_NEW)执行数据源切换可能不成 ...
- c++经典卡常
1.展开函数 如下代码: void lowbit(int x) { return x&(-x); } signed main() { cout << lowbit(12345); ...
- Easyexcel(3-文件导出)
响应头设置 通过设置文件导出的响应头,可以自定义文件导出的名字信息等 //编码格式为UTF-8 response.setCharacterEncoding("UTF-8"); // ...