本文首发于公众号“AntDream”,欢迎微信搜索“AntDream”或扫描文章底部二维码关注,和我一起每天进步一点点
问题出现的步骤
-
首先通过
SourceTree新建一个新的分支,新建分支的时候是基于远程分支的某次提交 -
然后将新建的分支推送到远程
-
最后在本地git目录文件夹中,通过git的checkout命令检出远程分支
git checkout -b 本地分支名 远程分支名
以上,就会报 fatal:‘XXX' is not a commit and a branch 'dev' cannot be created from it的错误
问题原因
远程新建的分支没有更新到本地。实际上,git仓库分为本地仓库和远程仓库,我们用checkout命令是从本地仓库中找要检出的分支的。本地仓库只有在进行网络请求时才会跟远程仓库交互,比如fetch命令。
问题解决
更新远程仓库数据到本地,可以用2个命令
-
fetch命令git fetch origin需要注意的是origin是远程仓库名,如果只有一个远程仓库,第一次克隆时Git 会自动为你将此远程仓库命名为
origin -
update命令git remote update origin --prune这个命令会更新远程的分支到本地
最后再执行checkout命令即可检出新建的分支
欢迎关注我的公众号查看更多精彩文章!