关于git分支的合并策略

图片发自简书App

实验一下午,终于得出关于git分支的合并策略。今天,我本在安静的敲项目,直到写完某个小功能,我想提交代码的时候!由于项目组最近将SVN改成了Git,所以对于更新操作还不是很熟悉!于是我发现了一个问题!

那么这个问题就是:

当我创建了一个主分支(将原来svn的代码拷入),然后每个开发人员再分别fork或者直接在原项目创建分支(效果类似),比如我创建的分支wq和我组长创建的cy!此时cy和wq内容是一样的!

问题来了:首先,我的组长效率就是高,他先将属于他模块的某功能完成,然后提交了代码到他的cy分支下,并且由于这次更新也算完成了一个功能,于是组长决定合并分支,他将cy分支合并到master主分支,此时master还属于刚刚创建的状态,组长是第一个合并者,结果当然没有任何问题!代码合并成功,master分支中多了组长改动的那些文件!仅止于此的话,是没有啥问题的,这也是我们刚接触git时,遇到的情况; 但随着时间推移,我的模块也完成了某一功能,我也决定将代码提交到远程分支(前面提交的分支当然也是远程,这里的提交不单单指git commit), 好的,首先我提交到了wq分支,接下来是合并,合并前,我同步了我本地的master分支,由于我没有操作我本地的master分支,所以同步非常顺利(直接用的pull,用fetch也行),接下来我要合并我的wq分支到master分支中,那么问题来了! 是否会因为master中修改了我组长的代码和我的wq分支不同,而我的wq分支中修改我的那个功能的代码又与master中不同,那么,如果用git查看不同(git diff wq或git diff master),会看到所有的修改(包括wq中我的模块与master的不同/master中我组长的模块与wq分支的不同),但是,此时在master分支下使用git merge wq会发生什么呢?

经过分析,有以下可能:

1.wq中的不同代码更改同步到了master中,同时master中的不同代码也同步到了wq,组后master与wq无差别.

2.wq中的不同代码更改同步到了master中,而master中的不同代码没有同步到wq

3.master中的不同代码也同步到了wq,而wq中的不同代码没有同步到master

于是,经过我的实验,发现真实情况是可能 2,并且当在wq分支中调用git merge master时, 真实情况变为可能3!

这是为什么呢? 经过我的分析,原来,merge命令的用处是,将git merge 后接的 名为< name >分支中的更改(比如在master中输入git merge wq的用处就是仅将wq中我修改的代码同步到master中,而对于master中被修改的代码与wq虽然不同,但不是wq的更改,所以不同步),反之在wq中输入git merge master的则将master中我组长后来提交的代码同步到我的wq分支中,而对于wq中我的修改,并不会覆盖为master中的代码(即一开始从svn拷过来,功能还未实现的版本,还好是这样,不然我辛辛苦苦写代码,不就没有了?). 如此就解释了如何使用git merge !

很简单,无非在不同情况在不同的分支下进行同步而已!

比如:

1.我只想将刚修改的代码提交合并到master分支(同时提交到远程) ,那么就先将master分支更新到最新版本,然后在切换到master下(git checkout master) ,合并wq分支:git merge wq,当然在此之前你可以看看你做了啥更改:git diff wq.

2.我不但想提交代码,还想观摩一下我组长大神的代码(毕竟是大神), 那么也很简单,首先,按照1的步骤,合并,然后,切换到wq分支下:git checkout wq,合并master的修改到wq:git merge master

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

推荐阅读更多精彩内容