git merge,rebase和*(no branch)
上一篇:http://blog.csdn.net/xiaoputao0903/article/details/23933589,说了git的分支,相关的使用方法没说到可是仅仅要google就能搜出一大片,这里还有几个细节要注意一下,就是merge合并和rebase合并的差别,以及*(no
branch)的处理。
1.merge
在上篇介绍分支的时候有简单的说了一下分支的创建和合并,当时合并就是写的merge,这是依据两个不同分支的最后一次提交的commit对象c5,c7和两个分支的交叉点的commit对象c3进行一次简单的三方合并,终于得到一个新的commit来作为终于的提交commit对象c8,指针指向c8,并且c4,c5,c6,c7是存在于本地仓库的历史版本号,我们能够通过日志查看找到这两个commit,相同也能够恢复到这两个版本号。也就是以下这个图:
上图是将test分支合并到master分支,然后我们来实现一次,假如如今已经到了c3,我新建一个分支test,然后先用master分支改动我的test.txt文件并提交反复两次,得到c4和c5,然后再切换到test分支相同对test.txt改动并提交两次,得到c6和c7,然后切换到master分支运行合并操作,这时会提示有冲突,最后我们解决冲突了再提交:
冲突:
日志:
2.rebase
rebase称为衍合,这是个什么概念呢,例如以下图,当我们把test衍合到master的时候,是将c5,和c6中发生的变化打成补丁然后再c8的基础上做改动的,假设这个时候遇到冲突,就必需要我们自己决绝好冲突之后,加入到暂存区然后再继续合并,c5的变化补丁在c8上发生变化之后得到c5'这个commit对象,而c6的变化补丁再在c5'上改动得到c6',然后指针指向c6',这个过程我们称之为衍合,并且这个过程都是在一个*(no branch)分支上做的,这个后面会说到。并且有一个要注意的地方,假设git运行git
gc或者我们手动运行git gc,那么c5和c6就不再存在于我们的本地仓库,我们就再也找不回这两个commit了,这个过程就是一个线性的过程,在test运行完之后,再在test的基础上运行master的操作。以上就是rebase和merge的差别所在。
和merge一样,我们实际来做一次,如果如今我们已经在c4了,这时候创建test分支,全部改动操作和merge一样,然后我们用rebase这样的方式来把test衍合到master上:
冲突:
日志:
3.*(no branch)
在运行命令git branch查看分支的时候,假设出现*(no branch),则表示不在不论什么分支上进行工作。出现这样的情况我也是在几次不经意之间,用git checkou回溯版本号的时候,用git pull或者merge和rebase的时候会出现*(no branch)。眼下我在rebase的时候都是在*(no branch)上进行的,当衍合完毕后自己主动切到master上,我认为这是个正常现象,可是其它几种方式就不正常了,详细原因我也不是非常清楚。
因为*(no branch)表示不在不论什么分支上进行,而有时我们不知道自己是在*(no branch)上进行操作的,并且可能我们已经进行非常久的开发工作了,已经提交好几个版本号的代码了,突然运行git branch发如今*(no branch)上,是不是一件非常恐怖的事啊。
当然经过提交的版本号数据都会以快照的方式被记录在commit对象存在.git文件夹的objects子文件夹里,那么当我们发现是在*(no branch)时应该怎么解决呢。有两种情况。
第一种情况是我们还没离开*(no branch),这个时候,我们能够运行git checkout -b mybranch命令,这个时候会创建新分支mybranch,并将*(no branch)里面的数据都checkout到mybranch分支上,然后我们再在mybranch上开发,终于合并到master上。
另外一种情况就不乐观了,我们已经离开*(no branch)了,然后发现用git log都找不到之前的提交了,当然了,在*(no branch)上提交的,在别的分支上怎么找的到在它上面提交的数据呢。只是或许还有救,假设git还没有运行git gc,那么我们能够通过运行git reflog找到在*(no branch)上提交的数据,然后依据找到的commit的id来恢复该数据,这也是最后唯一的希望了,假设git已经运行了git gc或者你手贱自己运行了git gc,那么就真的不能在一起愉快的玩耍了。
所以在运行过git checkout恢复过曾经的数据或者是做过合并分支的操作,那么不要吝啬你们的git branch,敲这个命令又不要钱,却能让你之后的提交高枕无忧。
4.总结
merge的合并是三方合并,并且历史版本号都在本地方库中,可是却比較繁琐,并且开发的过程是个网状结构,假设创建的分支比較多,进行的merge也比較多,那么就算我们在纸上画它的提交历史都会画的手疼,可是rebase就不一样,它是依据另外一个分支的改动内容进行打补丁然后在前一个分支的最后提交上进行改动,并且将另外一个分支的提交历史删除,这样就是一个线性的过程,非常清晰。所以在推送到远程仓库之前尽量多用rebase来衍合分支,可是假设将一个commit推送到远程仓库之后,就不要再对它进行衍合操作了,由于这种话,它非常可能在你的某次衍合过程中被删除,那么再推送到远程仓库就会造成非常大的损失。切记,rebase虽好可不要贪杯。
git merge,rebase和*(no branch)的更多相关文章
- Git merge rebase cherry-pick 以及 游离commit 的测试
Microsoft Windows [版本 10.0.17134.345] (c) Microsoft Corporation.保留所有权利. C:\Users\zhangyang\Desktop\b ...
- git merge / rebase 分支的新建与合并
merge https://git-scm.com/book/zh/v2/Git-%E5%88%86%E6%94%AF-%E5%88%86%E6%94%AF%E7%9A%84%E6%96%B0%E5% ...
- git merge rebase的区别及应用场景
前两天和同事交流发现他在日常开发中跟上游保持同步每次都是用git pull操作,而我一直习惯git fetch然后rebase,发现这两种操作后的log是有些区别的.他每次pull操作之后都会自动生成 ...
- git merge 到 非当前 branch
1. Add a remote alias for your local repository, ex: git remote add self file:///path/to/your/reposi ...
- git merge & git rebase
git merge & git rebase bug error: You have not concluded your merge (MERGE_HEAD exists). hint: P ...
- Difference between git pull and git pull --rebase
个人博客地址: http://www.iwangzheng.com/ 推荐一本非常好的书 :<Pro Git> http://iissnan.com/progit/ 构造干净的 Git ...
- 关于git merge,rebase合并的差别,以及*(no branch)的处理。
1.merge 在上篇介绍分支的时候有简单的说了一下分支的创建和合并,当时合并就是写的merge,这是依据两个不同分支的最后一次提交的commit对象c5,c7和两个分支的交叉点的commit对象c3 ...
- git 开发merge rebase 记录
git status git lg git add src/ git commit -m "restful api and portal" //先commit到自己的本地branc ...
- git merge 与 rebase
git merge git rebase merge V.S. rebase 参考材料 写在开始: 对merge和rebase的用法总有疑惑,好像两个都能完成"获取别的branch的comm ...
随机推荐
- Android Content Provider的启动过程源码分析
本文參考Android应用程序组件Content Provider的启动过程源码分析http://blog.csdn.net/luoshengyang/article/details/6963418和 ...
- mysql学习之中的一个:mysql安装
我用的时mac系统,本来想在mac系统上装一个,可是发现mac系统始终无法用password登入到本机server,很奇怪的问题(在stackflow上看了些回复,也没有找到原因),最后仅仅好装到虚拟 ...
- [置顶] 让导入的Android项目,运行起来的方法。
Eclipse里面直接import的代码,不能运行出现如下错误: [2013-12-12 12:58:55 - Dex Loader] Unable to execute dex: java.nio. ...
- Appium 的安装启动
Appium 的安装方式根据官网提供的是使用nodejs 安装,但是官方给出了三种方法 参考网址: appium下载地址: https://bitbucket.org/appium/appium.ap ...
- qt学习笔记(七)之数据库简介(所有支持数据库类型的列表)
笔者最近用Qt写公司的考勤机.本来要求是要基于frameBuffer下用自己开发的easyGUI来进行上层应用开发,但是考虑到easyGUI提供的接口不是很多,就考虑用Qt来开发,顺带练练手. 废话不 ...
- maven生成war包的两种方式
war包即对WEB应用程序进行打包,用于应用容器的部署.如在jboss中只要把war包丢入deploy目录下即可发布自己的应用了.打包方式有很多中,很多工具本身就支持此功能.下面主要介绍通过maven ...
- [置顶] 64位Win2008_VS2012使用ODP.NET遭遇问题和解决办法
最近为使用Oracle11G数据库做个快速开发的小程序,使用64位Win2008+Vs2012环境,结果碰壁连环,幸好不算太笨,终于解决了,特记录一下. 测试环境: Oracle11g (11.2.0 ...
- pygame编写贪吃蛇
一直想用pygame做一个小游戏的,可是因为拖延症的缘故一直没有动,结果那天看到了一个12岁的国际友人小盆友用pygame做的一款塔防游戏,突然感觉已经落后超级远了,所以心血来潮做小游戏了.高中陪伴我 ...
- Cocos2dx引擎10-事件派发
本文介绍Cocos2dx事件(以下简称Event)处理机制中的事件分发模块,在Event发生后,进过一系列处理,最后将会分发Event: 1.dispatchEvent& dispatchTo ...
- C keyword register 并讨论共同使用嵌入式汇编
C keyword register 并讨论共同使用嵌入式汇编 register 是C99 的keyword之中的一个. register 是储存类型之中的一个.这里仅讨论register 储存类型. ...