本文首发于公众号“AntDream”,欢迎微信搜索“AntDream”或扫描文章底部二维码关注,和我一起每天进步一点点
为什么已经推到远程的分支,我本地checkout的时候还是提示找不到分支?
首先我们要弄清楚的是,checkout 是本地命令,不跟远程仓库打交道。我们基于远程分支新建一个分支时一般会这样操作:
git checkout -b XXX origin/XXX
实际上,上面的命令并不是从远程仓库拉分支下来切换,而是从我们本地的远程引用中切换新分支,也就是从我们本地的Git仓库中的 refs/remotes 目录下面。
而本地的远程引用只有在和远程仓库沟通时才会更新。换句话说,我们的本地仓库很多时候并不是最新的,其他小伙伴推到远程的分支我们如果不拉取是没有的。
所以我们需要先更新一下,把新的分支拉到我们的本地仓库中,执行一下 git fetch 就好了。
Git fetch和Git pull
git fetch 是从远程仓库拉取本地没有的数据,不会修改工作目录的内容。获取的数据包括远程新的分支、新的提交等,更新的是远程引用。
git pull 基本就相当于 git fetch 加上 git merge,也就是除了拉取新的数据外,它还会把当前分支对应的远程分支上的内容 merge 到当前分支。所以很多时候,我们用 git pull 以后都会报冲突,就是因为Git自己执行了merge操作。
非常重要的是,如果我们是和其他小伙伴在同一个分支合作开发,我们在 push 之前,必须先

本文介绍了Git在处理分支时常见的问题,包括为何本地找不到远程分支、fetch与pull的区别、回滚远程分支的原理以及如何安全删除远程分支。重点解析了Git命令的使用,如fetch更新远程引用,pull合并数据可能引发的冲突,以及reset --hard的危险操作。还探讨了删除远程分支的命令及引用规格的灵活运用。
最低0.47元/天 解锁文章
1640

被折叠的 条评论
为什么被折叠?



