git rebase -i合并多次提交的实现

网络编程 2021-07-05 12:59www.168986.cn编程入门
这篇文章主要介绍了git rebase -i合并多次提交的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们狼蚁网站SEO优化随着长沙网络推广来一起学习学习吧

简介

在日常开发中,代码变更比较频繁,有时候想让前几次提交的合并为一次提交,这里可以使用git rebase -i 命令来完成,,git rebase命令不仅仅用于合并提交,它还有许多用处,比如可以使用git rebase onto将某一段mit粘贴到另一个分支上等等,这里主要介绍合并提交。

命令介绍

rebase为变基
git rebase -i 命令可以压缩合并多次提交
格式git rebase -i [startpoint] [endpoint]

其中-i的意思是–interactive,即弹出交互式的界面让用户编辑完成合并操作,[startpoint] [endpoint]则指定了一个编辑区间,如果不指定[endpoint],则该区间的终点默认是当前分支HEAD所指向的mit(注该区间指定的是一个前开后闭的区间)。

在查看git的log后,可以使用如下命令

// 合并从当前head到15f745b(mit id)
git rebase -i 15f745b
或:
// 合并最近的两次提交
git rebase -i HEAD~2

执行这个命令后会跳到一个vi编辑器

里面的提示有

  • pick保留该mit(缩写:p)
  • reword保留该mit,但我需要修改该mit的注释(缩写:r)
  • edit保留该mit, 但我要停下来修改该提交(不仅仅修改注释)(缩写:e)
  • squash将该mit和前一个mit合并(缩写:s)
  • fixup将该mit和前一个mit合并,但我不要保留该提交的注释信息(缩写:f)
  • exec执行shell命令(缩写:x)
  • drop我要丢弃该mit(缩写:d)

实操

这里在终端输入: git rebase -i HEAD~2 这里的 HEAD~2 表示合并最近两次的提交, 如果想合并最近三次的提交修改为: git rebase -i HEAD~3


需要做的是,将第二行的 pick 改为 s, “s” 为 “squash” 的缩写,“squash” 的意思是将这个提交压缩为一次提交


保存后弹出这样的

将 This is the mit message #2 狼蚁网站SEO优化的内容改成你想提交的概述即可


保存退出即可

到此这篇关于git rebase -i合并多次提交的实现的文章就介绍到这了,更多相关git rebase -i合并多次提交内容请搜索狼蚁SEO以前的文章或继续浏览狼蚁网站SEO优化的相关文章希望大家以后多多支持狼蚁SEO!

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by