merge remote-tracking branch 是什么意思_Git极简教程(3)--branch级别的操作

两个branch的合并(merge)

不同的remote之间是以branch来为单位来进行同步的,这就涉及到不同branch的合并了。我们先考虑一种简单的情况来理解合并(merge)操作:

d523b9852baa0dc0d4784d0bb6d617fd.png

左边是两台电脑上的情况,上面的人有三个改动,增加了a.txt文件,增加了b.txt文件,增加了c.txt文件;下面的人也有三个改动,增加了a.txt文件,增加了b.txt文件,增加了d.txt文件。如何合并这两个人的修改呢?最直观的方式,就是保留相同的修改,把不同的修改都保留,就好啦,像右边的图那样,最后,保留了四个改动:增加了a.txt文件,增加了b.txt文件,增加了c.txt文件,增加了d.txt文件。

所以,简单理解,如何合并两个branch呢?

  1. 保留两个branch相同的改动
  2. 保留两个branch不同的改动

这么一想,合并似乎很简单,把改动做个并集就行了。其实并不是的,两个branch合并的时候,有时候会有冲突,比如:

5df4a789975008e1f20075f17d83b4f9.png

左边是两个branch,模拟的是一个只有两行的文件。第一次改动,把第一行写上了a,第二次,两个branch分别在第二行写上了b和c,那么,在合并的时候,第一个公共的改动保留就可以了,可是第二个改动改采取哪一种呢?这就是改动发生了冲突(conflict),需要人来决定第二行该是什么内容,是b还是c还是bc,这叫冲突解决(resolve conflict)。

到这里,我们从概念上理解了两个branch是如何合并成一个branch的。

对于极简教程而言,我们不需要创建branch,只要使用默认的名为master的branch就好了。我们主要是和origin这个remote同步,而origin也有一个默认叫master的branch。所以,我们的主要任务是了解如何合并 master 与 origin/master。

git pull

这个命令是更新origin(比如朋友提交了新的改动,需要同步),然后把master与origin/master合并,把合并后的叫做新的master。其实,这个命令等价于下面的两个命令的组合:

git fetch origin
git merge origin/master

第一行就是更新origin,第二行是合并两个分支。

这个命令就是保持与最新的公共版同步。

在开始工作之前,请先 git pull , 保持与朋友的最新版处于同步状态,避免冲突。

如果冲突了,那只能手动解决。推荐使用VS Code解决。

b91e39fe9a2767bd2a51b6619fb87a3f.png

检测到一个文件有冲突时,VS Code在打开的时候就会明显地显示出来,大部分时候只要点一下上面四个按钮里面的一个就可以达到效果。

修改好之后,执行 git add -u && git merge --continue 就可以啦。

git push

当我们在自己的电脑上做出了一些改动的时候,我们可以用这条命令把自己电脑上的改动同步到云端。

branch级别的操作就介绍到这里,后面再介绍怎么保存每一个改动。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值