Git 合并多次 commit 、 删除某次 commit

栏目: IT技术 · 发布时间: 5年前

内容简介:Git 合并多次 commit 、 删除某次 commit

Git 合并多次 commit

有时候在一个分支的多次意义相近的 commit,会把整个提交历史搞得很混乱,此时可以将一部分的 commit 合并为一个 commit,以美化整个 commit 历史,可以使用 rebase 的方法来合并多次 commit,主要步骤如下:

1. git log 查看当前的提交历史

比如需要将以下 3 个 ”请假应用客户端代码优化“ 的 commit 合并为一个 commit; 

Git 合并多次 commit 、 删除某次 commit

2. git rebase 进行 git 压缩

执行 git rebase -i HEAD~4 对最近的 4 个 commit 进行 rebase 操作;

Git 合并多次 commit 、 删除某次 commit

具体的操作下面的 Commands 说明得很清楚了,对于 commit 合并可以使用 squash、fixup 指令,区别是 squash 会将该 commit 的注释添加到上一个 commit 注释中,fixup 是放弃当前 commit 的注释;

Git 合并多次 commit 、 删除某次 commit

Git 合并多次 commit 、 删除某次 commit

编辑后保存退出,git 会自动压缩提交历史,如果有冲突,记得解决冲突后,使用 git rebase --continue 重新回到当前的 git 压缩过程;

Git 合并多次 commit 、 删除某次 commit

3. 推送到远程仓库 git push -f

重新查看提交提交历史,会发现这些 commit 已经合并了,整个提交历史简洁了很多:

Git 合并多次 commit 、 删除某次 commit

删除某次 commit 

同样的,利用 git 压缩 rebase 指令来删除某个 commit,过程和以上是类似的;

在 git log 下,假如我们需要删除“请假应用客户端代码优化”这个 commit:

Git 合并多次 commit 、 删除某次 commit

可以通过 git rebase -i HEAD~1 (对最近1次 commit 进行 rebase) 或 git rebase -i 9fbf10(对 commit id 前几位为 9fbf10 的 commit 之后的 commit 进行 rebase);

Git 合并多次 commit 、 删除某次 commit

 将需要删除的 commit 设置操作指令 drop ,保存退出即可;

Git 合并多次 commit 、 删除某次 commit

 在执行 git log 时,可以发现该条 commit 已经从提交历史中删除了;


以上所述就是小编给大家介绍的《Git 合并多次 commit 、 删除某次 commit》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

标签: git rebase git rebase

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

GOOGLE HACKS

GOOGLE HACKS

Rael Dornfest、Tara Calishain / 卞军、谢伟华、朱炜 / 电子工业 / 2006-1 / 49.00元

GOOGLE HACKS巧妙使用网络搜索的技巧和工具(第二版)一起来看看 《GOOGLE HACKS》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换