通常,合并分支时,如果可能,Git会用Fast forward
模式,但这种模式下,删除分支后,会丢掉分支信息。
如果要强制禁用Fast forward
模式,Git就会在merge时生成一个新的commit,这样,从分支历史上就可以看出分支信息。
面我们用--no-ff
方式的git merge
:
创建dev分支,然后修改东西,提交,切回master分支, --no-ff表示禁用Fast forward:
git merge --no-ff -m "hahahahah" dev
因为本次合并要创建一个新的commit,所以加上-m
参数,把commit描述写进去。
可以看到,不使用Fast forward
模式,merge后就像这样:
实际开发中,我们应该按照几个基本原则进行分支管理:
首先,master
分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活;
干活都在dev
分支上,dev
分支是不稳定的,到某个时候,比如1.0版本发布时,再把dev
分支合并到master
上,在master
分支发布1.0版本;
你和你的小伙伴们每个人都在dev
分支上干活,每个人都有自己的分支,时不时地往dev
分支上合并就可以了。