如何简洁地把一份代码提交到不同的git分支

引言

我们有时需要向两个git分支上提交相同的代码。这时,我们可能要分别创建两个commit提交到两个分支。用cherry-pick可以省去手工复制粘贴的麻烦:

$ git cherry-pick <commit_id>

这样就可以把指定的commit复制一份添加到另外一个分支的头部。

cherry-pick满足了我们的需求,只要提交代码,切换分支,再用一下cherry-pick就可以完成两个分支的提交。

---o---A  branch_a

---o---A' branch_b (A和A'提交的是一样的代码修改)

然而,这样的做法会创建重复的commit,让我们的代码仓库看上去又臃肿又乱,这一点也不DRY(don't repeat yourself)。

一个提交合并到两个分支

那为啥不直接把1个commit用到两个分支呢?如果你往a分支提交1个commit然后合并到b分支,结果就是a分支的所有commit都会被合并到b分支。

---A---B---C---commit branch_a
                  \
---o---o---o-------o  branch_b (现在也有A, B, C)

我们肯定不想这么做,除非你本来就想把a合并到b。但是我们可以想一想,能不能创建一个分支c,里面只有a和b共有的commit,然后在c上修改代码,然后把c合并到a和b?这样的话,因为a和b已经有之前的commit了,只有后来你需要的那个commit才会被加到a和b里面。

---A---B---o branch_a
           /
---commit<   branch_c (可以把"commit"同时合并到a和b)
           \
---P---Q---o branch_b

这个想法不错,但是这样的分支怎么得到呢?实际上,我们的开发分支a和b往往是在某个commit上分叉出来的,假设这个commit是x,那么x以及之前的commit都是a和b的共有的commit。于是我们可以在x上创建分支c,然后把代码修改提交到c,就可以同时把c合并到a和b了。

            A---B---C---o branch_a
           /           /
o---...---X-----commit<   branch_c
           \           \
            P---Q---R---o branch_b

现在问题来了,怎么找到分支的最近公共commit,也就是x呢?答案是用git merge-base:

$ git merge-base branch_a branch_b
050dc022f3a65bdc78d97e2b1ac9b595a924c3f2

给出你想要合并代码的分支a和b,就可以返回最近公共commit的id,是个sha1的字符串。然后就可以用这个返回的commit来创建分支:

$ git branch <branch_name> <commit_id>

现在你把代码提交到新建的分支,就可以同时把它合并到分支a和b上了。

如果你已经在a或者b上提交代码了,别慌,用git rebase

缺点

这个方法不是总是可行的。如果遇到下面的情况,还是建议分开两个commit提交:

  1. 当有合并冲突时。分支a和b之间可能已经有很大的差别,尤其是最近公共commit已经很旧的情况。此时你需要一个额外的commit来处理冲突,而且因为是从可能很旧的分支c基础上添加代码的,可能会产生更多的冲突。
  2. 当修改的代码是以前就提交到一个分支,现在想提交到另一个分支时。除非这个commit刚好在最近公共commit的后面并且你可以rebase,否则还是再复制一份commit吧。

总结

这篇文章讨论了在多个分支提交同一份代码的方法。虽然提到的方法并不是使用git的时候必须的,但是因为它可以让你的git提交记录更干净和直观,个人比较推荐。

本作品采用知识共享署名-相同方式共享 4.0 国际许可协议进行许可。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容

  • 走一段山路 赏一幅美景 诗人游 淋一场大雨 赏一轮明月 诗人瘦 酌一杯烈酒 写一首小诗 诗人惆 感一次人生 讲一个...
    简_图阅读 375评论 0 2
  • 在刚刚学习了VIM编辑器后,我们都会进行一些练习。但当我们遇到某些问题,往往不得不在用VIM编辑文本的时候强行退出...
    羽恋心阅读 628评论 0 2
  • 原来坚持自己喜欢做的事情也是有一定的难度
    木蓝木兰阅读 393评论 0 0
  • 今天看了古典专栏《三步,让优势助力自我发展》的内容,受启发,明白了一些道理,也解决了自己原有的一些困惑。 ...
    如雾如电阅读 175评论 0 2