branch

git branch 列出、创建与管理工作上下文    git checkout 切换到新的分支上下文

git branch 命令是 Git 中的通用分支管理工具,可以通过它完成多项任务。 我们先说你会用到的最多的命令 —— 列出分支、创建分支和删除分支。 我们还会介绍用来切换分支的 git checkout 命令。

git branch 列出可用的分支

没有参数时,git branch 会列出你在本地的分支。你所在的分支的行首会有个星号作标记。 如果你开启了彩色模式,当前分支会用绿色显示。

$ git branch
* master

此例的意思就是,我们有一个叫做“master”的分支,并且该分支是当前分支。 当你执行 git init 的时候,缺省情况下 Git 就会为你创建“master”分支。 但是这名字一点特殊意味都没有 —— 事实上你并不非得要一个叫做“master”的分支。 不过由于它是缺省分支名的缘故,绝大部分项目都有这个分支。

git branch (branchname) 创建新分支

我们动手创建一个分支,并切换过去。执行 git branch (branchname) 即可。

$ git branch testing
$ git branch
* master
  testing

现在我们可以看到,有了一个新分支。当你以此方式在上次提交更新之后创建了新分支,如果后来又有更新提交, 然后又切换到了“testing”分支,Git 将还原你的工作目录到你创建分支时候的样子 —— 你可以把它看作一个记录你当前进度的书签。让我们实际运用看看 —— 我们用 git checkout (branch) 切换到我们要修改的分支。

$ ls
README   hello.rb
$ echo "test content" > test.txt
$ echo "more content" > more.txt
$ git add *.txt**
$ git commit -m "added two files"
[master 8bd6d8b] added two files
 2 files changed, 2 insertions(+), 0 deletions(-)
 create mode 100644 more.txt
 create mode 100644 test.txt
$ ls
README   hello.rb more.txt test.txt
$ git checkout testing
Switched to branch "testing"
$ ls
README   hello.rb

当我们切换到“测试”分支的时候,我们添加的新文件被移除了。切换回“master”分支的时候,它们有重新出现了。

$ ls
README   hello.rb
$ git checkout master
Switched to branch "master"
$ ls
README   hello.rb more.txt test.txt

git checkout -b (branchname) 创建新分支,并立即切换到它

通常情况下,你会更希望立即切换到新分支,从而在该分支中操作,然后当此分支的开发日趋稳定时, 将它合并到稳定版本的分支(例如“master”)中去。 执行 git branch newbranch; git checkout newbranch 也很简单, 不过 Git 还为你提供了快捷方式:git checkout -b newbranch

$ git branch
* master
$ ls
README   hello.rb more.txt test.txt
$ git checkout -b removals
Switched to a new branch "removals"
$ git rm more.txt
rm "more.txt"
$ git rm test.txt
rm "test.txt"
$ ls
README   hello.rb
$ git commit -am "removed useless files"
[removals 8f7c949] removed useless files
 2 files changed, 0 insertions(+), 2 deletions(-)
 delete mode 100644 more.txt
 delete mode 100644 test.txt
$ git checkout master
Switched to branch "master"
$ ls
README   hello.rb more.txt test.txt

如你所见,我们创建了一个分支,在该分支的上下文中移除了一些文件,然后切换回我们的主分支,那些文件又回来了。 使用分支将工作切分开来,从而让我们能够在不同上下文中做事,并来回切换。

创建新分支,在其中完成一部分工作,完成之后将它合并到主分支并删除。你会觉得这很方便,因为这么做很快很容易。 如此,当你觉得这部分工作并不靠谱,舍弃它很容易。并且,如果你必须回到稳定分支做些事情, 也可以很方便地这个独立分支的工作先丢在一边,完成要事之后再切换回来。

git branch -d (branchname) 删除分支

假设我们要删除一个分支(比如上例中的“testing”分支,该分支没啥特殊的内容了), 可以执行 git branch -d (branch) 把它删掉。

$ git branch
* master
  testing
$ git branch -d testing
Deleted branch testing (was 78b2670).
$ git branch
* master

简而言之 使用 git branch 列出现有的分支、创建新分支以及删除不必要或者已合并的分支。

文章导航