原创作品,转载请标明:http://blog.csdn.net/jackystudio/article/details/12309627

Rebase,衍合?变基?唉,我也不知道要怎么翻译合适。。。变基怪怪的,我擦勒,你才变基呢。。。

1.Rebase提交

rebase命令允许你编辑你的提交历史,比如你可以把多个提交(commit)联合成一个,可以对它重新排序,跳掉某个提交或者编辑提交信息。这是非常有用的,当你要再推送到远程仓库之前要想重新编辑提交信息。以下举个例子把多个提交联合成一个。

[cpp] 
view plain
copy

 

  1. #做一些无聊的修改和提交
  2. $ echo "test_rebase1" > jackydata01
  3. $ git commit -a -m "test_rebase1"
  4. [master 128a2f5] test_rebase1
  5. 1 file changed, 1 insertion(+), 1 deletion(-)
  6. $ echo "test_rebase2" > jackydata01
  7. $ git commit -a -m "test_rebase2"
  8. [master 5ae88f5] test_rebase2
  9. 1 file changed, 1 insertion(+), 1 deletion(-)
  10. $ echo "test_rebase3" > jackydata01
  11. $ git commit -a -m "test_rebase3"
  12. [master 37be873] test_rebase3
  13. 1 file changed, 1 insertion(+), 1 deletion(-)
  14. $ echo "test_rebase4" > jackydata01
  15. $ git commit -a -m "test_rebase4"
  16. [master 7dff3e4] test_rebase4
  17. 1 file changed, 1 insertion(+), 1 deletion(-)
  18. $ echo "test_rebase5" > jackydata01
  19. $ git commit -a -m "test_rebase5"
  20. [master 897fa79] test_rebase5
  21. 1 file changed, 1 insertion(+), 1 deletion(-)

看一下log。

[cpp] 
view plain
copy

 

  1. $ git log --pretty=oneline
  2. 897fa79def2cf256b7f14d0ec0fcb67e8f61a814 test_rebase5
  3. 7dff3e4ad7416f0370b4579393a0c8a8fc02efbd test_rebase4
  4. 37be873b514afd9d8f6536cd893eadc3e32b4966 test_rebase3
  5. 5ae88f5a0454066d820f6c1687b6d01f59f39dbd test_rebase2
  6. 128a2f5cdb325bcbdb26b35741fad2a2fba49832 test_rebase1
  7. ...还有很多

利用《git rebase》把最后5个(如上)提交联合为1个。

[cpp] 
view plain
copy

 

  1. git rebase -i HEAD~5

这个时候会打开Vim,这款神器我就不多说了,爱的多,恨的也不少,在Ubuntu上用过,自己不熟练所以感觉效率不高。Vim的常用命令自己google吧。

2.Rebase分支

对多个分支进行rebase操作,rebase命令为一个分支的更改生成一个补丁,然后把这个补丁应用到另外一个分支上,那么最后的源代码和merge是一样的,使用这种方式进行分支的合并更为合理。

[cpp] 
view plain
copy

 

  1. #创建并跳转到分支br
  2. $ git branch br
  3. $ git checkout br
  4. Switched to branch 'br'
  5. #修改br分支中的Jackydata01
  6. $ echo "this wiil be rebase to master" >jackydata01
  7. #提交br分支中的修改
  8. $ git  commit -a -m "rebase to master"
  9. [br 5c2a431] rebase to master
  10. 1 file changed, 1 insertion(+), 1 deletion(-)
  11. #跳转到master分支
  12. $ git checkout master
  13. Switched to branch 'master'
  14. Your branch is ahead of 'origin/master' by 1 commit.
  15. (use "git push" to publish your local commits)
  16. #使用rebase把br的改变应用到master
  17. $ git rebase br
  18. First, rewinding head to replay your work on top of it...
  19. Fast-forwarded master to br.
  20. #显示master中jackydata01的内容
  21. $ cat jackydata01
  22. this wiil be rebase to master

[置顶] 【Git入门之十】Rebase操作的更多相关文章

  1. [置顶] 【Git入门之十五】Github操作指南

    原创作品,转载请标明:http://blog.csdn.net/jackystudio/article/details/12374633 最终篇,介绍一下Github网站的使用,主要是翻译为主,简化了 ...

  2. [置顶] 【Git入门之十四】Git GUI

    原创作品,转载请标明:http://blog.csdn.net/jackystudio/article/details/12374495 文章都快写完了,Git GUI才浮出水面,很多人要骂我,这么方 ...

  3. 简单的git入门介绍及常用操作

    集中式版本控制系统采用中央服务器上存储的所有文件和实现团队协作.但是CVCS主要缺点是中央服务器的单点故障,即故障.不幸的是,如果中央服务器宕机一小时,然后在该时段没有人可以合作.即使在最坏的情况下, ...

  4. Git入门——本地版本库操作

    作为一个一直用SVN的家伙,深深地感到了自己在版本控制工具上的落伍.... 首先必须强调的是: Git与Github不是一回事. Git是目前世界上最先进的分布式版本控制系统,于2005年被linux ...

  5. [置顶] Git学习总结(1)——Git使用详细教程

    一:Git是什么? Git是目前世界上最先进的分布式版本控制系统. 二:SVN与Git的最主要的区别? SVN是集中式版本控制系统,版本库是集中放在中央服务器的,而干活的时候,用的都是自己的电脑,所以 ...

  6. Inno Setup入门(十)——操作注册表 & 自启程序

    http://379910987.blog.163.com/blog/static/3352379720110259414788/ 有些程序需要随系统启动,或者需要建立某些文件关联等问题,这些都是通过 ...

  7. [置顶] JUnit入门教程(二)

    一:介绍 接着上次的课程,今天我们学习JUnit4的新特性 assertThat()方法,这种方式和其余的assert方法比起来,更加接进英语. 二:分析API API中的例子: 参数 T Actua ...

  8. Inno Setup入门(十)——操作注册表

    有些程序需要随系统启动,或者需要建立某些文件关联等问题,这些都是通过在安装程序中对注册表进行操作的结果.Inno Setup中通过[registry]段实现对注册表的操作. 本段说明: 参数列表: 参 ...

  9. Inno Setup入门(十)——操作注册表

    有些程序需要随系统启动,或者需要建立某些文件关联等问题,这些都是通过在安装程序中对注册表进行操作的结果.Inno Setup中通过[registry]段实现对注册表的操作. 本段说明: 参数列表: 参 ...

随机推荐

  1. Two-Phase-Commit for Distributed In-Memory Caches--reference

    Part I reference from:http://gridgain.blogspot.kr/2014/09/two-phase-commit-for-distributed-in.html 2 ...

  2. 手势识别 GestureDetector ScaleGestureDetector

    识别器GestureDetector基本介绍 当用户触摸屏幕的时候,会产生许多手势,例如down,up,scroll,filing等.一般情况下,我们可以通过View或Activity的onTouch ...

  3. js接收复选框的值

    <td><input type="checkbox" class="title" name="title" value=& ...

  4. 服务器端调用Word组件读取Word权限、未将对象引用到对象实例终极解决方案

    最近因为业务需要,需要在服务器上调用Word组件,结果遇到各种问题,比如检索 COM 类工厂中 CLSID 为 {000209FF-0000-0000-C000-000000000046} 的组件失败 ...

  5. SQL从入门到基础–03 SQLServer基础1(主键选择、数据插入、数据更新)

    一.SQL语句入门 1. SQL语句是和DBMS“交谈”专用的语句,不同DBMS都认SQL语法. 2. SQL语句中字符串用单引号. 3. SQL语句中,对于SQL关键字大小写不敏感,对于字符串值大小 ...

  6. 升级openssl到1.0.1g

    先进行支撑包的安装: # yum install -y zlib   openssl升级步骤: 下载最新版本的openssl源码包 # wget ftp://ftp.openssl.org/sourc ...

  7. MyEclipse内存不足的问题

    今早打开MyEclipse莫名其妙弹出提示框,然后我各种搜索,用了网上能查到的各种办法去试图解决问题,方法包括但不限于  修改eclipse.ini .设置Default VM Arguments . ...

  8. iOS9中通过UIStackView实现类似大众点评中的效果图

    效果图如下: 实现思路 整体可以看做为一个大的UIStackView(排列方式水平)包括一个子UIStackView(排列方式垂直),其中左边包括一个图片,右边的UIStackView中可以看做包括三 ...

  9. [转载] HDFS and Erasure Codes (HDFS-RAID)

    The Hadoop Distributed File System has been great in providing a cloud-type file system. It is robus ...

  10. 记录Linux下安装elasticSearch时遇到的一些错误

    记录Linux下安装elasticSearch时遇到的一些错误 http://blog.sina.com.cn/s/blog_c90ce4e001032f7w.html (2016-11-02 22: ...