博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Git Merging vs. Rebasing
阅读量:4050 次
发布时间:2019-05-25

本文共 871 字,大约阅读时间需要 2 分钟。

– Start


假设现在有两个任务,张三干一个,李四干一个,李四的任务部分依赖张三,也就是说,他们同时创建分支开始干活,等张三的任务完成,合并分支到主分支 master 后,李四需要把主分支master 的改动同步到自己的分支,怎么办?目前的状况是这样的。

这里写图片描述

这个时候我们有两种办法,merge 和 rebase。

在之前的章节中我们已经讲过 merge,merge 后的结果如下。
这里写图片描述

merge 最大的问题就是会污染提交日志,所以我们推荐使用 rebase,请看下图。

这里写图片描述

知道 rebase 的含义了吧,看看以前的 base 在哪里,现在的base在哪里。

现在我们演示一下 rebase,先创建分支 zhangsan 和 lisi,然后在zhangsan分支创建一个新文件,提交,修改后在提交,然后 merge 回 master。

git branch zhangsangit branch lisigit checkout zhangsanecho "zhang" > zhangsan.txtgit add zhangsan.txtgit commit -m "create zhangsan.txt"echo "san" >> zhangsan.txtgit add zhangsan.txtgit commit -m "first modify zhangsan.txt"git checkout mastergit merge zhangsan

这时,我们切换到 lisi 分支然后看看rebase后的结果。

git checkout lisigit loggit rebase mastergit log

到此为止,聪明的人已经想到了,我们是不是也可以使用 rebase 把bug分支合并到主分支maser呢?千万别这么干,否则你的噩梦才干干开始。

– 更多参见:

– 声 明:转载请注明出处
– Last Updated on 2018-06-09
– Written by ShangBo on 2018-06-09
– End

你可能感兴趣的文章
C primer plus 基础总结(一)
查看>>
剑指offer算法题分析与整理(三)
查看>>
Ubuntu 13.10使用fcitx输入法
查看>>
pidgin-lwqq 安装
查看>>
mint/ubuntu安装搜狗输入法
查看>>
C++动态申请数组和参数传递问题
查看>>
opencv学习——在MFC中读取和显示图像
查看>>
C/C++中关于动态生成一维数组和二维数组的学习
查看>>
JVM最简生存指南
查看>>
JVM并发机制探讨—内存模型、内存可见性和指令重排序
查看>>
持续可用与CAP理论 – 一个系统开发者的观点
查看>>
nginx+tomcat+memcached (msm)实现 session同步复制
查看>>
c++字符数组和字符指针区别以及str***函数
查看>>
c++类的操作符重载注意事项
查看>>
c++模板与泛型编程
查看>>
WAV文件解析
查看>>
WPF中PATH使用AI导出SVG的方法
查看>>
WPF UI&控件免费开源库
查看>>
QT打开项目提示no valid settings file could be found
查看>>
Win10+VS+ESP32环境搭建
查看>>