## git branch 列出、创建与管理工作上下文 git checkout 切换到新的分支上下文
`git branch` 命令是 Git 中的通用分支管理工具,可以通过它完成多项任务。 我们先说你会用到的最多的命令 —— 列出分支、创建分支和删除分支。 我们还会介绍用来切换分支的 `git checkout` 命令。
### git branch 列出可用的分支
没有参数时,`git branch` 会列出你在本地的分支。你所在的分支的行首会有个星号作标记。 如果你开启了[彩色模式](http://git-scm.com/book/en/Customizing-Git-Git-Configuration#Colors-in-Git),当前分支会用绿色显示。
~~~
$ 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` 列出现有的分支、创建新分支以及删除不必要或者已合并的分支。