git 拉取远程其他分支代码_【Git】第九章:深度图解分支内部原理远程分支

远程仓库操作命令:

删除本地的远程仓库地址地址:

git  remote  rm  origin

添加本地的远程仓库地址地址:

git remote  add  origin http://192.168.1.108/wilee/wileeproject.git

修改本地的远程仓库地址地址:

git  remote  set-url  origin  http://192.168.1.108/wilee/wileeproject.git

1、远程仓库目前提交历史:

865b12772f5b75975984cdf52e2396b2.png

因为远程仓库没有进行过推送所以目前的提交历史还是上图的状态。

张三和李四本地提交历史中的origin/master就是对应着远程仓库master分支。

2、张三执行push操作

张三执行命令git push origin master

因为本地的master跟远程分支origin/master是关联起来的,origin/master就对应着远程仓库的master分支,所以执行上述命令之后,实际上会做两件事情:

     第一是修改本地的origin/master分支。

     第二是将本地的commit提交历史推送到远程仓库,修改远程仓库的master指针。

7136086d172de8cf34d1491cd8e806a1.png

上图中注意origin/master所在的commit,发现它到了fb7c243这个commit上面了。提交历史如下图所示:

cdca8b5a407f7d60f61aef389e235050.png

因为origin/master和master是关联起来的,只要一执行git push origin master命令,首先在本地就会将origin/master的指针移动到本地的master分支一样。同时会将本地的commit提交历史推送到远程仓库里面去,远程仓库的master也指向了最新的commit。

3、李四执行push操作
a. 李四执行命令git push origin master后会报错。

94a72e8c4af6970a63e17357a64a3bad.png

报错的意思就是说,远程的仓库里的master分支的代码已经有人提交过了,然后此时是不能直接推送新的代码到master分支的需要先执行git pull命令;

b. 李四执行git pull

此时的git pull会做两件事情:

第一件事情,将远程仓库的commit提交历史拉取下来跟本地的提交历史进行合并。

第二件事情,将本地的master分支对应的commit跟远程仓库的master分支对应的commit进行合并

608909cea79cebb78ec0836fa3088229.png

此时git  pull会执行一下merge操作,我们来看一下李四的log

da842b9d9c4f16307f7ac8939ab26351.png

李四把master中的commit树拉倒了本地,然后会做一个merge,因为本地的master与origin/master不在一条commit线上所以说要进行一个合并操作。

李四的提交历史图,如下图所示:

42c471d304659a67ca28e6eabf667f5e.png

因为要进行合并操作,所以会多出来一个commit,是origin/master与本地master对应的commit合并而来的commit。

c. 李四再次执行命令git push origin master

18a7baa2367ec1dfd9fb41c70c9b518e.png

此时远程仓库的提交历史就会把李四的commit树加入进去:

88148ff708fb1329af225a27b72beb81.png

4、张三执行git pull

张三做最后一个操作执行一次git pull,将远程仓库的提交历史拉取到本地进行合并,让本地仓库跟远程仓库保持一致。

162de569aeb621a37987a363e732d0e4.png

远程分支冲突解决

常见于这样的一种场景,同一个分支中张三与李四修改了同一行代码,张三提交并push到了远程仓库。李四此时要push报错,要先git pull。李四跟张三的master分支代码合并的时候发生了冲突,不知道该听谁的。所以说,这个时候就需要进行冲突的解决。

李四进行push操作:

8629da6f2d8a7aec003daa2afee8b3a9.png

李四进行pull操作:

df6d7d2ff2d50b9353b64865a4e2c21b.png

发现有冲突在TestController中。

5d09ca499b9d55a61c62cdeadcde69b0.png

<<<<<<< HEAD  System.out.println("我是李四 发现了bug");======  System.out.println("我是张三发现bug");>>>>>> 23a5e60e6b8fe8ad916bc01cf5ab7f0595be8e87

这里的HEAD指的意思是说,李四本地的HEAD指针指向的分支对应的commit中的代码。

23a5e60e6b8fe8ad916bc01cf5ab7f0595be8e87,指的是张三修改后提交的commit对应的hash值。

删除特殊符号即可解决冲突:

6288eeec85fc2cc347318e6168d5248b.png

再进行提交和push即可。

解决冲突的原理其实就是李四pull下来的commit树发现有冲突后根据当前分支与远程分支进行合并在本地形成一个新的commit。再对这个commit进行push到远程仓库中。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值