git merge-快进合并和非快进合并
来源:互联网 发布:手机淘宝售后退款流程 编辑:程序博客网 时间:2024/06/06 03:37
git merge
git merge其实有很多参数的哦,我们来看看merge有哪些参数可以供我们选择:
git merge -n <branch> 不会在合并后显示合并前后的不同状态
git merge –stat <branch> 跟上面的参数相反,它会在合并结束后显示合并前后的不同状态
git merge -e <branch> 在合并之前会调用配置的编辑器,您可以自己编写commit,否则的话commit的内容就是git自动生成的
git merge –no-commit <branch>相当于一次快进式合并,不会生成一次提交,如下图所示:
git merge –stat <branch> 在合并后会显示不同的状态,如下图红色框中部分:
git merge –no-stat <branch> 合并后不会显示不同的状态,如下图:
git merge –quiet <branch> 无声的合并(不会输出任何信息)
git merge –ff <branch> 当合并是快进式合并的时候,仅仅是更新了分支的指针,不会产生合并提交,这也是默认的合并行为
git merge –no-ff <branch> 及时是快进式合并,也会创建一个合并提交
git merge –ff-only <branch> 只允许快进式合并
快进式合并和非快进式合并
何为快进式合并??
如果当前的分支和另一个分支没有内容上的差异,就是说当前分支的每一个提交(commit)都已经存在另一个分支里了,git 就会执行一个“快速向前”(fast forward)操作;git 不创建任何新的提交(commit),只是将当前分支指向合并进来的分支。
快进式和非快进式的区别:
目前仓库的状态是,master分支上有了5次提交,然后基于master创建分支test,并在test上进行3次提交,接下来,我在master分支上对test分支分别进行快进式和非快进式合并。
先进行快进式合并, git merge test (默认为–ff合并),如下图所示,我们看到一共是5+3=8个提交,分支的提交历史也没有“开叉”,即没有多个父提交节点。
随后,我回到master的第五次提交,然后对test进行非快进式合并,git merge –no-ff test
这时候,同快进式合并不同的是,在c5处产生了“开叉”,然后新生成了一个commit “Merge branch 'test'”,即多了一个父提交。
现在,大家应该对这两种合并有了一种直观的了解了吧。
非快进式合并
非快进式合并会生成新的提交,并“开叉”,可以让我们的提交历史更加的清晰!
http://www.cnblogs.com/hutaoer/archive/2013/03/14/3078869.html
- git merge-快进合并和非快进合并
- Git 非快进方式合并没有共同历史的远程分支
- 快进
- Git实验室——快进式推送(FastForwards)与非快进式推送(NonFastForwards)
- Git协同工作之——非快进式推送
- git merge 合并分支
- Git merge和git branch 分支与合并
- Git merge和git branch 分支与合并
- Git merge 合并分区详解
- Git merge 合并分区详解
- Git merge 合并分区详解
- Git merge 合并分区详解
- Git merge 合并分区详解
- git命令之git merge 合并分支
- Git技巧之解决git merge的合并冲突(非树冲突)
- 三,快进式推送(FastForwards)与非快进式推送(NonFastForwards)
- git merge合并分支解决冲突
- Git代码合并Merge还是Rebase
- php -- PDO属性设置
- 文本处理工具awk
- C中的struct与C++中的struct区别以及C++中的struct与C++中的class的区别
- 如何部署vuejs项目到Tomcat上
- 腾讯大规模Hadoop集群实践 [转程序员杂志]
- git merge-快进合并和非快进合并
- iOS修改UITextField的placeholder的字体颜色大小
- java nio
- 欢迎使用CSDN-markdown编辑器
- nosql 数据库概况一二
- 平方等式问题
- ajax请求错误status=0(Provisional headers are shown)
- Python wordcloud之中文词云
- 图片即时优化的三种简单解决方案