git rebase是对提交执行变基的操作.即可以实现将指定范围的提交"嫁接"到另外一个提交智商.

其常用的命令格式有:

用法1:git rebase --onto <newbase> <since> <till>

用法2:git rebase --onto <newbase> <since>

用法3:git rebase                             <since> <till>

用法4:git rebase                             <since>

用法5:git rebase -i

用法6:git rebase --continue

用法7:git rebase --skip

用法8:git rebase --abort

用法6,7,8是在变基过程中被中断时可以采用的命令------继续变基或终止等.

用法6是在变基遇到冲突而暂停的情况下.先完成冲突解决(添加到暂存区,不提交),然后在恢复变基操作的时候使用该命令.

用法7是在变基遇到冲突而暂停的情况下,跳过当前提交的时候使用.

用法8是在变基遇到冲突而暂停的情况下,终止变基操作.回到之前的分支时候使用.

>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>.

git merge是用来合并两个分支的。

git merge b

# 将b分支合并到当前分支

同样 git rebase b,也是把 b分支合并到当前分支

他们的 原理 如下

假设你现在基于远程分支"origin",创建一个叫"mywork"的分支。
$ git checkout -b mywork origin
假设远程分支"origin"已经有了2个提交,如图
 
现在我们在这个分支做一些修改,然后生成两个提交(commit).
$ vi file.txt
$ git commit
$ vi otherfile.txt
$ git commit
...
但是与此同时,有些人也在"origin"分支上做了一些修改并且做了提交了. 这就意味着"origin"和"mywork"这两个分支各自"前进"了,它们之间"分叉"了。
 
在这里,你可以用"pull"命令把"origin"分支上的修改拉下来并且和你的修改合并; 结果看起来就像一个新的"合并的提交"(merge commit):
但是,如果你想让"mywork"分支历史看起来像没有经过任何合并一样,你也许可以用 git rebase:
$ git checkout mywork
$ git rebase origin
这些命令会把你的"mywork"分支里的每个提交(commit)取消掉,并且把它们临时 保存为补丁(patch)(这些补丁放到".git/rebase"目录中),然后把"mywork"分支更新 为最新的"origin"分支,最后把保存的这些补丁应用到"mywork"分支上。
当'mywork'分支更新之后,它会指向这些新创建的提交(commit),而那些老的提交会被丢弃。 如果运行垃圾收集命令(pruning garbage collection), 这些被丢弃的提交就会删除. (请查看 git gc)
二、解决冲突
在rebase的过程中,也许会出现冲突(conflict). 在这种情况,Git会停止rebase并会让你去解决 冲突;在解决完冲突后,用"git-add"命令去更新这些内容的索引(index), 然后,你无需执行 git-commit,只要执行:
$ git rebase --continue
这样git会继续应用(apply)余下的补丁。
在任何时候,你可以用--abort参数来终止rebase的行动,并且"mywork" 分支会回到rebase开始前的状态。
$ git rebase --abort
三、git rebase和git merge的区别
现在我们可以看一下用合并(merge)和用rebase所产生的历史的区别:
当我们使用Git log来参看commit时,其commit的顺序也有所不同。
假设C3提交于9:00AM,C5提交于10:00AM,C4提交于11:00AM,C6提交于12:00AM,
对于使用git merge来合并所看到的commit的顺序(从新到旧)是:C7 ,C6,C4,C5,C3,C2,C1
对于使用git rebase来合并所看到的commit的顺序(从新到旧)是:C7 ,C6‘,C5',C4,C3,C2,C1
 因为C6'提交只是C6提交的克隆,C5'提交只是C5提交的克隆,
从用户的角度看使用git rebase来合并后所看到的commit的顺序(从新到旧)是:C7 ,C6,C5,C4,C3,C2,C1

最新文章

  1. SQLserver CASE WHEN
  2. 【bzoj2435】[NOI2011]道路修建
  3. SQL Server 一列或多列重复数据的查询,删除
  4. HDU 2512 一卡通大冒险
  5. PHP Date/Time 函数
  6. Windows 8实例教程系列 - 开篇
  7. centos 6.9安装zabbix 3.0
  8. 《奇思妙想:15位计算机天才及其重大发现》【PDF】下载
  9. 1.QT开发第一个程序
  10. ThreadPoolExecutor系列一——ThreadPoolExecutor 机制
  11. CentOS7 下更改源
  12. SqlServer2008备份与还原(完整图示版)
  13. Install Nginx on CentOS 7
  14. jquery插件与扩展一
  15. 算法导论-MIT笔记
  16. CentOS 开启安装EPEL YUM源
  17. 一图看懂hadoop Yarn工作原理
  18. hadoop从调整GC到关键Counter计算原理分析
  19. angular的service与factory
  20. sgu 131 状压DP

热门文章

  1. double free or corruption的原因
  2. C# Debug与release之间的一些小差异
  3. wuzhicms短信API 实例调用
  4. UVA1673 str2int(SAM)
  5. mysql fetch 系列函数
  6. stm32f10x.h文件分析理解
  7. PT100测温函数
  8. ios开发 json数据文件的存取
  9. thinkPHP配置项
  10. MySQL数据库备份还原(基于binlog的增量备份)