| 注册
请输入搜索内容

热门搜索

Java Linux MySQL PHP JavaScript Hibernate jQuery Nginx
无限互联
7年前发布

图解4种git合并分支方法

   <p>有时候我们会后悔,有时候我们会想回到过去,有时候我们想改变历史,然而在我们这个世界,目前来看是无法回到过去改变历史的</p>    <p>但在git的世界里,一切皆有可能,我们可以在多维空间里任意切换,随意改变一个宇宙的时间线,只要我们愿意,git的分支就是这么神奇</p>    <p>然而很多时候你以为你改变了历史,不为人知,那个宇宙并没有消失,而是遗失在了git的世界里,有能力的人便能找到</p>    <p>彼此分开的世界也能随时交叉合并,世界就这样开开合合,偶会需要解决合并冲突</p>    <p>git中的分支非常的轻量,其实就是一个文件,里面记录了分支所指向的commit id,下图中有两个分支分别是master和test,他们都指向了A2这个提交,HEAD是一个特殊的指针,他永远指向你当前所在的位置;有时候你可能不在某一个分支上,不要惊慌,你随时有权利去你想去的分支,git赋予了你新建,切换分支的能力</p>    <p><img src="https://simg.open-open.com/show/1415881fa1cf0181841d6e55bae34f59.png"></p>    <p>然后有时候世界并不总如上图那般美好,面对分叉的两个分支,git新手总是一脸茫然,本文我将讲述git中合并分支的方法</p>    <p>在git中合并分支有三种方法,分别是merge,rebase,cherry-pick,而其中merge又有三种区别,下面将一一介绍</p>    <h2>fast-forward</h2>    <p>如果待合并的分支在当前分支的下游,也就是说没有分叉时,会发生快速合并,从test分支切换到master分支,然后合并test分支</p>    <pre>  git checkout master  git merge test</pre>    <p>这种方法相当于直接把master分支移动到test分支所在的地方,并移动HEAD指针</p>    <p><img src="https://simg.open-open.com/show/831b7c4cb3a51dbe8956c26a96344319.gif"></p>    <h2>no-ff</h2>    <p>如果我们不想要快速合并,那么我们可以强制指定为非快速合并,只需加上 --no-ff 参数</p>    <pre>  git checkout master  git merge –no-ff test</pre>    <p>这种合并方法会在master分支上新建一个提交节点,从而完成合并</p>    <p><img src="https://simg.open-open.com/show/cccf8ec398e3cdc67ed8fb1d4eda517a.gif"></p>    <h2>squash</h2>    <p>svn的在合并分支时采用的就是这种方式,squash会在当前分支新建一个提交节点</p>    <p>squash和no-ff非常类似,区别只有一点不会保留对合入分支的引用</p>    <pre>  git checkout master  git merge –squash test</pre>    <p><img src="https://simg.open-open.com/show/4882ab29a0325582042f3d39e76f2529.gif"></p>    <h2>rebase</h2>    <p>当要合并两个分叉的分支时,merge的方式是将待合入分支和当前分支不同的部分,在当前分支新建节点,如下图所示</p>    <p><img src="https://simg.open-open.com/show/17685a2a38e4fbbced3917be0d73d18c.png"></p>    <p>rebase与merge不同,rebase会将合入分支上超前的节点在待合入分支上重新提交一遍,如下图,B1 B2会变为B1' B2',看起来会变成线性历史</p>    <p><img src="https://simg.open-open.com/show/1267b522b02fd56778fdfae770910494.png"></p>    <h2>cherry-pick</h2>    <p>这命令简直就是神器,给你自由,你想把那个节点merge过来就把那个节点merge过来,其合入的不是分支而是提交节点</p>    <h2>总结</h2>    <p>只有知道了这些合并方式的区别,才能git在手,天下我有,任你分支在凌乱,我自岿然不动</p>    <h2>继续学习</h2>    <ul>     <li><a href="/misc/goto?guid=4959751682081400082" rel="nofollow,noindex">起底Git-开篇</a></li>     <li><a href="/misc/goto?guid=4959751682172354890" rel="nofollow,noindex">起底Git-版本控制简史</a></li>     <li><a href="/misc/goto?guid=4959751682256210151" rel="nofollow,noindex">起底Git-Git简史</a></li>     <li><a href="/misc/goto?guid=4959751682346385609" rel="nofollow,noindex">起底Git-Git内部原理</a></li>     <li><a href="/misc/goto?guid=4959751682427592007" rel="nofollow,noindex">起底Git-Git基础</a></li>     <li><a href="/misc/goto?guid=4959751682523661104" rel="nofollow,noindex">起底Git-Git进阶</a></li>     <li><a href="/misc/goto?guid=4959751682601982405" rel="nofollow,noindex">起底Git-Git开发流程</a></li>     <li><a href="/misc/goto?guid=4959751682696799609" rel="nofollow,noindex">起底Git-Git常用命令总结</a></li>    </ul>    <p>来自: <a href="/misc/goto?guid=4959751682786380303" rel="nofollow,noindex">http://yanhaijing.com/git/2017/07/14/four-method-for-git-merge/</a></p>    <p> </p>    
 本文由用户 无限互联 自行上传分享,仅供网友学习交流。所有权归原作者,若您的权利被侵害,请联系管理员。
 转载本站原创文章,请注明出处,并保留原始链接、图片水印。
 本站是一个以用户分享为主的开源技术平台,欢迎各类分享!
 本文地址:https://www.open-open.com/lib/view/open1503488015158.html
Git 版本控制系统