一切福田,不離方寸,從心而覓,感無不通。

git fetch & pull详解

1、简单概括

先用一张图来理一下git fetchgit pull的概念:

可以简单的概括为:

git fetch是将远程主机的最新内容拉到本地,用户在检查了以后决定是否合并到工作本机分支中。

git pull 则是将远程主机的最新内容拉下来后直接合并,即:git pull = git fetch + git merge,这样可能会产生冲突,需要手动解决。

下面我们来详细了解一下git fetch 和git pull 的用法。

2、分支的概念

在介绍两种方法之前,我们需要先了解一下分支的概念:
分支是用来标记特定代码的提交,每一个分支通过SHA1sum值来标识,所以对分支的操作是轻量级的,你改变的仅仅是SHA1sum值。

如下图所示,当前有2个分支,A,C,E属于master分支,而A,B,D,F属于dev分支。

 

它们的head指针分别指向E和F,对上述做如下操作:

 

合并完成后:

 

现在ABCDEFG属于master,G是一次合并后的结果,是将E和F的代码合并后的结果,可能会出现冲突。而ABDF依然属于dev分支。可以继续在dev的分支上进行开发:

 

分支(branch)的基本操作:

 

3、git fetch 用法

git fetch 命令:

 

如果只想取回特定分支的更新,可以指定分支名:

 

最常见的命令如取回origin 主机的master 分支:

 

取回更新后,会返回一个FETCH_HEAD ,指的是某个branch在服务器上的最新状态,我们可以在本地通过它查看刚取回的更新信息:

 

如图:

可以看到返回的信息包括更新的文件名,更新的作者和时间,以及更新的代码(19行红色[删除]和绿色[新增]部分)。

我们可以通过这些信息来判断是否产生冲突,以确定是否将更新merge到当前分支。

4、git pull 用法

前面提到,git pull 的过程可以理解为:

 

即将远程主机的某个分支的更新取回,并与本地指定的分支合并,完整格式可表示为:

 

如果远程分支是与当前分支合并,则冒号后面的部分可以省略:

 

from:https://www.cnblogs.com/runnerjack/p/9342362.html