【git pull与git pull --rebase的区别】

问题描述

在与团队合作开发项目时,为了方便项目的管理,我们会使用git进行项目的管理。当功能开发被分割时,我们对不同的branch分支进行提交操作,在开发的时候,我们有时候需要使用git pull来拉取他人的提交来更新项目的改动。
我们知道git pull即等于git fetch加上git merge,但还有另一种方式进行拉取他人的提交,即就是加上--rebase参数的git pull,但这两种方式有什么区别吗?

git fetch

git fetch 实现了本地仓库对远程仓库的提交的同步。此时本地仓库的数据文件并未发生改动,但本地的提交记录已经与远程仓库同步。

git merge

例如:对于当前分支master(*)提交(c3)和一个分支bugFix(c2),两者都基于c1提交,现在想要合并master和bugFix,使用git merge bugFix则会创建一个新的节点(提交)基于c2和c3 。


git pull --rebase则相当于git fetch加上git rebase
区别就在于,git rebase的效果。

git rebase

实际上就是取出一系列的提交记录,“复制”它们,然后再另外一个地方逐个的放下去。

例如:还是有分支bugFix的最新提交c2和分支master(*)的最新提交c3,两者都基于c1这个父节点,使用git rebase bugFix会在bugFix的c2下创建一个c3’(bugFix指向它),c3’只指向c2(即bugFix的最新提交),值得注意的是,提交记录c3依然存在,c3’是我们rebase到bugFix分支上的c3的副本。

git merge与git rebase的效果如图:
在这里插入图片描述

总结

现在git pull <branch>git pull --rebase <branch>的效果就清楚了。
最后附上一个关于git使用的小技巧的远程仓库:https://github.com/521xueweihan/git-tips

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值