本文首发于公众号“AntDream”,欢迎微信搜索“AntDream”或扫描文章底部二维码关注,和我一块儿天天进步一点点git
首先咱们要弄清楚的是,checkout
是本地命令,不跟远程仓库打交道。咱们基于远程分支新建一个分支时通常会这样操做:github
git checkout -b XXX origin/XXX
复制代码
实际上,上面的命令并非从远程仓库拉分支下来切换,而是从咱们本地的远程引用中切换新分支,也就是从咱们本地的Git仓库中的 refs/remotes
目录下面。bash
而本地的远程引用只有在和远程仓库沟通时才会更新。换句话说,咱们的本地仓库不少时候并非最新的,其余小伙伴推到远程的分支咱们若是不拉取是没有的。微信
因此咱们须要先更新一下,把新的分支拉到咱们的本地仓库中,执行一下 git fetch
就行了。markdown
git fetch
是从远程仓库拉取本地没有的数据,不会修改工做目录的内容。获取的数据包括远程新的分支、新的提交等,更新的是远程引用。fetch
git pull
基本就至关于 git fetch
加上 git merge
,也就是除了拉取新的数据外,它还会把当前分支对应的远程分支上的内容 merge
到当前分支。因此不少时候,咱们用 git pull
之后都会报冲突,就是由于Git本身执行了merge
操做。url
很是重要的是,若是咱们是和其余小伙伴在同一个分支合做开发,咱们在 push
以前,必须先拉取一下。spa
git push origin HEAD --force
的原理是什么?其实是作了啥操做?其实是把本地分支指向的 commit
强制更新到了远程对应的分支。code
// -D 大写,表示强制删除 git branch -d branchName 复制代码
咱们知道分支其实是 resf/heads/
下面的一个文件,里面保存的是最新的一次 commit 的SHA-1值。实际上,删除分支就是删除了这个引用文件,那删除远程仓库的分支也就是删除远程仓库下面的对应分支的引用。orm
明白了删除远程仓库分支的原理,咱们来看看删除远程仓库分支的命令:
git push origin :branchName
复制代码
上面命令的意思就是将远程仓库的 branchName
的分支引用置为空。
上面的命令其实是一种引用规格的应用,引用规格的形式为 :,其中 <src>
和 <dst>
是一个模式(pattern)。以前在讲到 git fetch
的时候咱们提到了 Git仓库目录下的 config
文件:
[remote "origin"] url = https://github.com/schacon/simplegit-progit fetch = +refs/heads/*:refs/remotes/origin/* 复制代码
上面的 fetch
实际上就是应用到了引用规格,含义以前已经提到过,就是把远程仓库 refs/heads/
目录下的引用更新到本地仓库的 refs/remotes/origin/
。
实际上,咱们还能够设置 push
操做的引用规格。好比咱们想将当前的 master
分支推送到远程仓库的mymaster
分支,咱们就能够这样:
git push origin master:refs/heads/mymaster
复制代码
更进一步的,若是咱们想把本身分支都推送到远程仓库的 KAE
目录下,咱们就能够在 config
目录下更新一条关于 push
操做的引用规格:
[remote "origin"] url = https://github.com/schacon/simplegit-progit //fetch中冒号前面的表示是远程仓库的引用,后面的表示那些远程引用在本地所对应的位置 fetch = +refs/heads/*:refs/remotes/origin/* //push相反,前面的是本地的引用位置,后面的表示远程仓库的地址 push = refs/heads/*:refs/heads/ant/* 复制代码
通过上面的设置之后,咱们每次 push
都会把本地的分支推送到远程仓库的 ant/*
分支。
欢迎关注个人公众号查看更多精彩文章!
复制代码