ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
## 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` 列出现有的分支、创建新分支以及删除不必要或者已合并的分支。