理解和正确使用Merge和Rebase

作为一个有追求的开发者,我一定会选择更好的版本管理工具(Git), 使用中我们难免会在 Merge 和 Rebase 中选择其一用于合并分支。

Rebase 和 merge 都是被设计用于集成你所做的改变从一个分支到另一个分支,只是通过不同的方式。虽然目的相同,但不同的方式有不同的优缺点。

区别

例如:我们有下面的几个commit,merge会将一些commit的组合作为一个结果,而rebase会将所有commit添加到目标分支的最近一次提交之后。

 

 

merge 会存在合并的历史记录,而rebase没有了历史记录且成一条直线。

Merge

  • 简单易理解
  • 源分支和目标分支相互分离
  • 保留功能分支的提交历史和分支图形
  • 分支一旦较多显示比较混乱

Rebase

  • 简化复杂的记录且线性可读
  • 没有合并的记录
  • 多个commit冲突时必须一个个提交去修改
  • 对远程分支rebase需要force push

什么时候使用rebase?什么时候使用merge ?

  • 独立开发

    如果你不是团队合作开发,那么你可以优先选择使用rebase来保持你整洁的提交历史。

  • 准备code review

    你需要在合并的时候有人来给你review,此时你需要提交一个 merge/pull request,此时别人可review你的代码后会执行merge,这将保存你此次的请求合并的记录,已备将来追溯。

  • 合并到多个目标分支或其他人正在使用当前分支

    这是应该使用merge,因为你执行rebase时,当前分支原先的commit会被删除(会影响他人),形成新的commit连接在目标分支最新commit之后。所以在这个条件不成立的时候你可以使用rebase来合并分支。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值