日期:2019 年 9 月 29 日
关于 git pull 和 git pull origin develop 的区别
闲来无事,正于网上冲浪之际,一位漂亮小姐姐抛来一个问题:git pull 和 git pull origin develop 有啥区别,一个答案从脑海里一闪而过——没啥区别,但好像也不对,没啥区别的话为啥还搞两个命令,至少秉着简单性原则来讲是这样的。于是乎,我又去网上溜了一圈,结合最近实际操作时遇到的小情况,整合除来下面的理解:
</br>
两者的区别
git pull origin develop
git pull origin develop 动作是去获取远程仓库中 develop 分支上的 commits,然后把origin/develop merge 到你目前 checkout 下来的分支中
git pull
git pull 就是去你之前 checkout 的分支上去操作,比如,如果你本地的 checkout 的分支track 的就是 origin/develop,那么 git pull 就等于 git pull origin develop
结合我遇到的情况加深理解
背景介绍
我拿到的项目 git 仓库原本是只有一个 master 分支,我自己新建了一个本地 develop 分支和另一个本地的分支(这个本地分支就是我们开发时用的),每次提交代码时,首先在开发分支中 commit,然后切换到 develop 中进行 merge , 然后把本地的 develop 推到远程的 develop 分支上,这样屡试不爽
意外情况
最近,在 develop 上按以往的习惯进行 git pull 操作,却没有成功,画面如下:
它提示我说我的这个 develop 分支还没有设置 track 信息,所以可以选择使用 git pull origin develop 命令,或者我要是想设置 track 信息的话,可以使用 git branch --set-upstream-to=origin/<branch> develop 命令
按照它的提示,我操作了一哈,首先用一哈 git pull origin develop:
可以看到已经是最新鲜的代码了,没毛病,说明成功了!
然后我再设置一下 track 信息:
OK,大功告成,我让本地 develop 分支跟踪远程的 develop 分之后,再进行 git pull 操作就没有提示了,这个时候实际上和进行 git pull origin develop 是一回事了