| 
                            
                                  简单概括两者的概念git fetch是将远程主机的最新内容拉到本地,用户在检查了以后决定是否合并到工作本机分支中。而git pull 则是将远程主机的最新内容拉下来后直接合并,即:git pull = git fetch + git merge,这样可能会产生冲突,需要手动解决。
 
 1.两者相同点先在作用上他们的功能是大致相同的,都是起到了更新代码的作用。 2.不同点首先我们要说简单说git的运行机制。git分为本地仓库和远程仓库,我们一般情况都是写完代码,commit到本地仓库(生成本地仓的commit ID,代表当前提交代码的版本号),然后push到远程仓库(记录这个版本号),这个流程大家都熟悉。我们本地的git文件夹里面对应也存储了git本地仓库master分支的commit ID 和 跟踪的远程分支orign/master的commit ID(可以有多个远程仓库)。那什么是跟踪的远程分支呢,打开git文件夹可以看到如下文件:
 
.git/refs/head/[本地分支].git/refs/remotes/[正在跟踪的分支]
 其中head就是本地分支,remotes是跟踪的远程分支,这个类型的分支在某种类型上是十分相似的,他们都是表示提交的SHA1校验和(就是commitID)。但是,不管他们是如何的相似,他们还是有一个重大的区别:更改远端跟踪分支只能用git fetch,或者是git push后作为副产品(side-effect)来改变。我们无法直接对远程跟踪分支操作,我们必须先切回本地分支然后创建一个新的commit提交。 拉取不同1、Git fetch:Git fetch会将数据拉取到本地仓库 - 它并不会自动合并或修改当前的工作。
 2、git pull:git pull是从远程获取最新版本并merge到本地,会自动合并或修改当前的工作。
 commitID不同
 1、Git fetch:使用Git fetch更新代码,本地的库中master的commitID不变,还是等于1。2、git pull:使用git pull更新代码,本地的库中master的commitID发生改变,变成了2。
 分支(branch)的基本操作
 
	
		
			| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 | git branch //查看本地所有分支   git branch -r //查看远程所有分支   git branch -a //查看本地和远程的所有分支   git branch <branchname> //新建分支   git branch -d <branchname> //删除本地分支   git branch -d -r <branchname> //删除远程分支,删除后还需推送到服务器 git push origin:<branchname>  //删除后推送至服务器   git branch -m <oldbranch> <newbranch> //重命名本地分支 /** *重命名远程分支: *1、删除远程待修改分支 *2、push本地新分支到远程服务器 */   //git中一些选项解释:   -d --delete:删除   -D --delete --force的快捷键   -f --force:强制   -m --move:移动或重命名   -M --move --force的快捷键   -r --remote:远程   -a --all:所有 |  3.git fetch用法git fetch 命令: 
	
		
			| 1 | $ git fetch <远程主机名> //这个命令将某个远程主机的更新全部取回本地 |  如果只想取回特定分支的更新,可以指定分支名: 
	
		
			| 1 | $ git fetch <远程主机名> <分支名> //注意之间有空格 |  最常见的命令如取回origin 主机的master 分支: 
	
		
			| 1 | $ git fetch origin master |  取回更新后,会返回一个FETCH_HEAD ,指的是某个branch在服务器上的最新状态,我们可以在本地通过它查看刚取回的更新信息: 
	
		
			| 1 | $ git log -p FETCH_HEAD |  
 可以看到返回的信息包括更新的文件名,更新的作者和时间,以及更新的代码(19行红色[删除]和绿色[新增]部分)。 我们可以通过这些信息来判断是否产生冲突,以确定是否将更新merge到当前分支。 4.git pull 用法前面提到,git pull 的过程可以理解为 
	
		
			| 1 2 | git fetch origin master //从远程主机的master分支拉取最新内容 git merge FETCH_HEAD    //将拉取下来的最新内容合并到当前所在的分支中 |  即将远程主机的某个分支的更新取回,并与本地指定的分支合并,完整格式可表示为: 
	
		
			| 1 | $ git pull <远程主机名> <远程分支名>:<本地分支名> |  如果远程分支是与当前分支合并,则冒号后面的部分可以省略: 5.拉取远程分支 
	
		
			| 1 2 3 | git fetch  //代码拉取到本地之后 git branch //查看分支 git checkout 远程分支的分支名 |  参考文章https://blog.csdn.net/qq_36113598/article/details/78906882
 https://blog.csdn.net/weixin_41975655/article/details/82887273 
 |