Git合并分支命令参数详解:git merge --ff
今天研究了一下git merge命令常用参数,并分别用简单的例子实验了一下,整理如下:
输入命令git merge -h可以查看相关参数:
--ff 快速合并,这个是默认的参数。如果合并过程出现冲突,Git会显示出冲突并等待手动解决
--ff-only 只有能快速合并的情况才合并。如果合并过程出现冲突,Git会自动abort此次merge
--no-ff 不使用快速合并。会生成一次新的提交记录,这个记录只是标识在这里进行了一次merge操作(目前还没想到应用场景)
--squash 压缩合并。将待合并的分支的内容压缩成一个新的提交合并进来
接下来分别模拟几种应用场景来举例说明,C代表一次提交,合并时都是将dev分支合并到master。
第一种情况:master分支切出dev分支后没有新的提交,也就是说只有dev分支有更新,可以快速合并的情况:
eg:master:C1 ← C2
↑
dev: C3 ← C4
1.执行:git merge --ff dev
master:C1 ← C2 ← C3 ← C4
dev:C1 ← C2 ← C3 ←C4
结果:查看git log时master分支会看到dev分支上的所有提交,此时master和dev是一样的
2.执行:git merge --ff-only dev
结果同上。
3.执行:git merge --no-ff dev
git会提示让你输入此次合并的信息,然后生成一个特殊的commit。
master:C1 ← C2 ← C3 ← C4 ← C5 (Merge branch 'dev')
dev:C1 ← C2 ← C3 ←C4
结果:master分支会比dev分支多一条提交记录,也就是刚才输入犯人合并信息
4.执行:git merge --squash dev
master:C1 ← C2 ← C5 (Merge branch 'dev')
dev:C1 ← C2 ← C3 ←C4
结果:这里的C5其实是C3和C4的合并,如果只想合并dev的内容但是不需要它的提交记录就可以用这个参数
第二种情况,切出后master和dev分支均有更新,这种情况是最常见的。这里为了演示冲突,在C4和C5分别对一个文件进行了修改。
eg:master:C1 ← C2 ← C4
↑
dev: C3 ← C5
1.执行:git merge --ff dev
这时Git会告诉你产生了冲突并列出冲突的文件,查看文件时会列出具体冲突内容,这时要先解决冲突(如果使用Intellij Idea或Eclipse等工具,可以直接选择use ours/theirs,ours代表被合并分支即master,theirs代表合并分支即dev),然后将这些修改的部分提交,再执行merge操作。
master:C1 ← C2 ← C3 ← C5 ← C4 ← C6 (解决冲突的那次提交)
dev:C1 ← C2 ← C3 ←C5
那么问题来了,Git是如何知道两个文件有冲突呢?
这里先说下结论,有时间再补一篇文章单独说明说明。
大家都知道在Git里每个文件都是一个blob对象,这里先不管合并时怎么找到同一个文件在两个分支上的blob(其实如果文件没有更新,在两个分支上是指向同一个blob),假设现在已经到了比较阶段了,Git会拿两个文件来逐行进行对比,但是判定是否修改是通过相邻行来确定的。也就是说文件a的第三行修改了,Git是通过第2行和第4行的对比来判定的,不信的可以先自己做实验验证。由于篇幅原因,这里不再赘述。
2.执行:git merge --ff-only dev
这时Git会检测到产生了冲突,所以提示:Not possible to fast-forward, aborting. 即取消这次merge操作。
3.执行:git merge --no-ff dev
结果同1,不过这里在解决了冲突执行commit操作后不用再进行merge操作了。如果再执行merge操作,它会提示:Already up-to-date.
4.执行:git merge --squash dev
master:C1 ← C2 ← C4 ← C6 (解决冲突的那次提交)
dev:C1 ← C2 ← C3 ←C5
这里解决了冲突并提交之后也不用再执行merge操作了。如果再执行merge操作会有两种情况:
a.刚才解决冲突时选用了master分支的修改,那么还是会提示有冲突需要解决。
b.刚才解决冲突时选用了dev分支的修改,那么会提示Already up-to-date。
对比发现,使用--squash参数时,如果有冲突,解决完冲突后只要两个分支不完全一样,再执行git merge --squash时还是会进行merge。但--no-ff就不会。
Git合并分支命令参数详解:git merge --ff的更多相关文章
- 3.3、Ansible命令参数详解
0.ansible 命令参数详解: [root@localhost ~]# ansible Usage: ansible <host-pattern> [options] Options: ...
- JAVA命令参数详解
JAVA命令参数详解 JAVA命令详解 结构 说明 Java 和 OldJava JIT 选项 另请参阅 结构 java [ options ] class [ argument ... ] java ...
- JAVA 命令参数详解System.setProperty(
JAVA 命令参数详解: 1.-D<name>=<value> set a system property 设置系统属性. java -D参数简化加入多个jar java命令 ...
- Oracle中用exp/imp命令参数详解【转】
Oracle中用exp/imp命令参数详解 [用 exp 数 据 导 出]:1 将数据库TEST完全导出,用户名system 密码manager 导出到D:\daochu.dmp中 exp sy ...
- nginx命令:启动,停止及命令参数详解
nginx命令:启动nginx 在Windows上安装好nginx后,我们需要启动nginx服务,启动nginx服务的命令行操作主要有两种方式,即 1 C:/nginx-0.8.53>nginx ...
- (转)Linux curl命令参数详解
Linux curl命令参数详解 命令:curl在Linux中curl是一个利用URL规则在命令行下工作的文件传输工具,可以说是一款很强大的http命令行工具.它支持文件的上传和下载,是综合传输工具, ...
- Spring Boot启动命令参数详解及源码分析
使用过Spring Boot,我们都知道通过java -jar可以快速启动Spring Boot项目.同时,也可以通过在执行jar -jar时传递参数来进行配置.本文带大家系统的了解一下Spring ...
- ffmpeg命令参数详解
ffmpeg命令参数详解 http://linux.51yip.com/search/ffmpeg ffmpeg图片加滤镜效果 参考:https://cloud.tencent.com/develop ...
- Linux中mpstat命令参数详解
Linux中mpstat命令参数详解 mpstat 是 Multiprocessor Statistics的缩写,是实时系统监控工具.其报告与CPU的一些统计信息,这些信息存放在 /proc/stat ...
随机推荐
- 初学springMVC的拦截器
springMvc拦截器的执行顺序! 拦截器的各个方法的作用: /** * 登录验证拦截器 */ public class Intercepter implements HandlerInt ...
- 终于遇到了传说的ie 6 img 3px的bug
最近在做一个网站,基本上已经算完成,就开始完善细节部分了. IE6可能是微软最为YD 的一款浏览器了吧,至今还没有退出历史的舞台,尽管google都宣布不在支持它了. 因为该死的ie6,虽死但是牢牢地 ...
- python 实现经典算法
import time start_time = time.clock() list_ = [9, 2, 7, 4, 5, 6, 3, 8, 1] """ # 堆排序(通 ...
- python cProfile分析程序性能
转自:http://xianglong.me/article/analysis-python-application-performance-using-cProfile/?utm_source=tu ...
- phpstudy无法访问主页,提示You don't have permission to access / on this server解决办法
1.输入localhost提示:You don't have permission to access / on this server. 新版phpStudy为了安全,取消Apache和nginx列 ...
- Google C++ 编码规范(中文版)
Google C++ 编码规范(英文)在线地址:http://google-styleguide.googlecode.com/svn/trunk/cppguide.xml 中文版PDF下载:本地下载
- git从远程仓库中更新代码到本地仓库
git从远程仓库中更新代码到本地仓库 有时候在使用git pull的时候,会莫名才报错.查了很多资料,尝试过git的很多命令.包括git fetch命令,都会报同样的错.最后终于发现了一条捷径,由网友 ...
- superviosrd进程管理
supervisor进程管理器---------------------------1. 安装依赖yum install python-setuptools-devel 2. 安装supervisor ...
- Quaternion Euler
geometry_msgs::Quaternion orientation = map->info.origin.orientation; tf::Matrix3x3 mat(tf:: ...
- javascript与java的不同之处
javascript与java的不同之处 虽然很像,但不是一种语言. 二者的区别体现在: 首先,它们是两个公司开发的不同的两个产品,Java是SUN公司推出的新一代面向对象的程序设计语言,特别适合 ...