git merge -ff --no-ff --squash 的区别

感谢原文作者:futureme

原文链接:https://www.cnblogs.com/taylorluo/articles/10810762.html

git merge #没有参数(默认为–ff)

即默认启用fast-forward方式进行合并,不会显示 feature,只保留单条分支记录。git直接把HEAD指针指向合并分支的头,完成合并。属于“快进方式”不过这种情况如果删除分支,则会丢失分支信息。因为在这个过程中没有创建commit

git merge --squash

用来把一些不必要commit进行压缩,比如说,你的feature在开发的时候写的commit很乱,那么我们合并的时候不希望把这些历史commit带过来,于是使用–squash进行合并,此时文件已经同合并后一样了,但不移动HEAD,不提交。需要进行一次额外的commit来“总结”一下,然后完成最终的合并。

git merge --no-ff

强行关闭fast-forward方式。可以保存你之前的分支历史。能够更好的查看 merge历史,以及branch 状态。

图示说明1

git merge -ff --no-ff --squash 的区别

图示说明2

git merge -ff --no-ff --squash 的区别

上一篇:git merge 将多个commit合并为一条之--squash 选项


下一篇:git merge的使用