git fetch, git pull, git pull -rebase区别
Posted mouseleo
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了git fetch, git pull, git pull -rebase区别相关的知识,希望对你有一定的参考价值。
git fetch, git pull, git pull -rebase区别
1、git fetch vs git pull
都是从远程拉取代码到本地,git fetch只是拉取到本地,git pull不仅拉取到本地还merge到本地分支中。所以git pull是git fetch与git merge的集合体。
详情参考: http://www.tech126.com/git-fetch-pull/
2、git pull 中的rebase参数用处
参考网页:http://blog.csdn.net/hudashi/article/details/7664631
假设现在有两个分支如下图所示:
如果想把origin分支的内容通过git merge到mywork分支,之后的效果如图所示:
如果采用git rebase呢,git rebase命令会把你的"mywork"分支里的每个提交(commit)取消掉,并且把它们临时 保存为补丁(patch)(这些补丁放到".git/rebase"目录中),然后把"mywork"分支更新 为最新的"origin"分支,最后把保存的这些补丁应用到"mywork"分支上。
最后效果如图所示:
如果在git pull的时候加上rebase参数,即git pull --rebase,这里表示把你的本地当前分支里的每个提交(commit)取消掉,并且把它们临时 保存为补丁(patch)(这些补丁放到".git/rebase"目录中),然后把本地当前分支更新 为最新的"origin"分支,最后把保存的这些补丁应用到本地当前分支上。
个人理解,其实用rebase还是不用rebase都可以实现代码的合并,用不用取决于你更重视哪一方的代码,如果认为origin是主要的,那么就加rebase,因为这样就能最大程度的保证origin代码不被你错误修改。
以上是关于git fetch, git pull, git pull -rebase区别的主要内容,如果未能解决你的问题,请参考以下文章
git fetch, git pull, git pull -rebase区别