添加链接
link之家
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
Git Merge 小技巧

Git Merge 小技巧

作者:dxweixiao

丹尼尔:Hi,蛋兄,周杰伦都出新专辑了,你咋还不更新啊,真的打算半年一更啊?

蛋先生:好像确实是这样,要不,择日不如撞日,今天聊聊?

丹尼尔:好啊,那聊些啥呢?

蛋先生:最近搞的事情需要实现两个应用项目的代码合并,逻辑就完全参照 git merge 的基本原则,那就聊聊 git merge

丹尼尔: git merge 我倒是经常用,不过却从未关心过它内部是怎么实现的。那你跟我讲一下它的工作原理呗。

合并的基本原则: three-way

蛋先生: git merge 的基本原则是 three-way

丹尼尔:3 条路?啥东东?

蛋先生:简单讲就是有 3 个分支。假设就叫 a, o, b,其中 a 和 b 都来自于 o,如下所示:

1.png

丹尼尔:嗯,然后呢?

蛋先生:现在 a 和 b 要进行合并。假设你当前在 a 分支,然后运行 git merge b ,那么合并结果是根据 a, o, b 之间的内容比较结果分析得出的。

丹尼尔:哦,嗯,比较逻辑是什么呢?

蛋先生:Very 简单。只要 a, o, b 任意两个的内容一致,就放弃 o 的内容;如果都不一样,就冲突。如下图所示

2.png

丹尼尔:只要...

蛋先生:我还是列举下所有的场景吧,然后你就会明白了

1). o == a, o != b

假设内容如下:
o: daniel
a: daniel
b: dx-b

a merge b 的结果: dx-b

2). o == b, o != a

假设内容如下:
o: daniel
a: dx-a
b: daniel

a merge b 的结果: dx-a

3). a == b, o != a

假设内容如下:
o: daniel
a: dx-ab
b: dx-ab

a merge b 的结果: dx-ab

4). o != a, o != b, a != b

假设内容如下:
o: dx-o
a: dx-a
b: dx-b

a merge b 的结果: 冲突

<<<<<<< a  
=======