[Git] 实验一下午,终于得出的结论,关于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> 后接的 名为< name >分支中的更改(比如在master中输入git merge wq 的用处就是仅将wq中我修改的代码同步到master中,而对于master中被修改的代码与wq虽然不同,但不是wq的更改,所以不同步),反之在wq中输入git merge master 的则将master中我组长后来提交的代码同步到我的wq分支中,而对于wq中我的修改,并不会覆盖为master中的代码(即一开始从svn拷过来,功能还未实现的版本,还好是这样,不然我辛辛苦苦写代码,不就没有了?).
如此就解释了如何使用git merge <name> !

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

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

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值