本文主要是介绍详解git pull和git fetch的区别,以及,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
转载!
原文:https://blog.csdn.net/weixin_41975655/article/details/82887273
作者:马恩光
直接看原文——详解git pull和git fetch的区别
补充示例——git fetch和git pull之间的区别
先补充一些git里面相关的一些知识:
-
首先我们要说简单说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提交。
git pull看起来像git fetch+get merge,但是根据commit ID来看的话,他们实际的实现原理是不一样的。
这里借用之前文献看到的一句话:
不要用git pull,用git fetch和git merge代替它。
git pull的问题是它把过程的细节都隐藏了起来,以至于你不用去了解git中各种类型分支的区别和使用方法。当然,多数时候这是没问题的,但一旦代码有问题,你很难找到出错的地方。看起来git pull的用法会使你吃惊,简单看一下git的使用文档应该就能说服你。
将下载(fetch)和合并(merge)放到一个命令里的另外一个弊端是,你的本地工作目录在未经确认的情况下就会被远程分支更新。当然,除非你关闭所有的安全选项,否则git。
pull在你本地工作目录还不至于造成不可挽回的损失,但很多时候我们宁愿做的慢一些,也不愿意返工重来。
作者:马恩光
来源:CSDN
原文:https://blog.csdn.net/weixin_41975655/article/details/82887273
版权声明:本文为博主原创文章,转载请附上博文链接!
这篇关于详解git pull和git fetch的区别,以及的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!