打赏

git 创建与合并分支

1、主分支

每次提交,Git都把它们串成一条时间线,这条时间线就是一个分支。截止到目前,只有一条时间线,在Git里,这个分支叫主分支,即master分支。HEAD严格来说不是指向提交,而是指向mastermaster才是指向提交的,所以,HEAD指向的就是当前分支。

一开始的时候,master分支是一条线,Git用master指向最新的提交,再用HEAD指向master,就能确定当前分支,以及当前分支的提交点:

 

每次提交,master分支都会向前移动一步,这样,随着你不断提交,master分支的线也越来越长。

2、dev

当我们创建新的分支,例如dev时,Git新建了一个指针叫dev,指向master相同的提交,再把HEAD指向dev,就表示当前分支在dev上:

Git创建一个分支很快,因为除了增加一个dev指针,改改HEAD的指向,工作区的文件都没有任何变化!

$ git checkout -b dev

git checkout命令加上-b参数表示创建并切换,相当于以下两条命令:

$ git branch dev
$ git checkout dev

git check 将指定的分支设置为当前分支。

查看当前分支:

$ git branch

git branch命令会列出所有分支,当前分支前面会标一个*号。

我们就可以在dev分支上正常提交。

$ git add readme.txt 
$ git commit -m "branch test"

从现在开始,对工作区的修改和提交就是针对dev分支了,比如新提交一次后,dev指针往前移动一步,而master指针不变:


3、分支合并

假如我们在dev上的工作完成了,就可以把dev合并到master上。Git怎么合并呢?最简单的方法,就是直接把master指向dev的当前提交,就完成了合并:

所以Git合并分支也很快!就改改指针,工作区内容也不变!

git merge命令用于合并指定分支到当前分支。

$ git merge dev

4、总结

查看分支git branch

创建分支git branch <name>

切换分支git checkout <name>

创建+切换分支git checkout -b <name>

合并某分支到当前分支git merge <name>

删除分支git branch -d <name>

 

posted @ 2018-04-25 11:38  孟繁贵  阅读(242)  评论(0编辑  收藏  举报
TOP