git分支

创建dev分支,然后切换到dev分支:
$ git checkout -b dev
git checkout命令加上-b参数表示创建并切换,相当于以下两条命令:
$ git branch dev
$ git checkout dev

然后,用git branch命令查看当前分支:
$ git branch
git因为创建、合并和删除分支非常快,所以鼓励你使用分支完成某个任务,合并后再删掉分支,这和直接在master分支上工作效果是一样的,但过程更安全。

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


git分支_第1张图片
git-br-create

Git创建一个分支很快,因为除了增加一个dev指针,改改HEAD的指向,工作区的文件都没有任何变化!不过,从现在开始,对工作区的修改和提交就是针对dev分支了,比如新提交一次后,dev指针往前移动一步,而master指针不变:


git分支_第2张图片
git-br-dev-fd

假如我们在dev上的工作完成了,就可以把dev合并到master上。Git怎么合并呢?最简单的方法,就是直接把master指向dev的当前提交,就完成了合并:
git分支_第3张图片
git-br-ff-merge

所以Git合并分支也很快!就改改指针,工作区内容也不变!合并完分支后,甚至可以删除dev分支。删除dev分支就是把dev指针给删掉,删掉后,我们就剩下了一条master分支:


git分支_第4张图片
git-br-rm

git分支常用命令:

查看分支:git branch // 查看本地分支 git branch -a // 查看本地远程所有分支

创建分支:git branch 

切换分支:git checkout 

切换到远程分支: git checkout -t origin/

创建+切换分支:git checkout -b 

合并某分支到当前分支:git merge 

删除分支:git branch -d 

注意:
当Git无法自动合并分支时,就必须首先解决冲突。解决冲突后,再提交,合并完成。
用git log --graph命令可以看到分支合并图。

分支策略

在实际开发中,我们应该按照几个基本原则进行分支管理:

首先,master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活;

那在哪干活呢?干活都在dev分支上,也就是说,dev分支是不稳定的,到某个时候,比如1.0版本发布时,再把dev分支合并到master上,在master分支发布1.0版本;

你和你的团队成员每个人都在dev分支上干活,每个人都有自己的分支,时不时地往dev分支上合并就可以了。

所以,团队合作的分支看起来就像这样:

git分支_第5张图片
git-br-policy

指定本地dev分支与远程origin/dev分支的链接 例如设置dev和origin/dev的链接:
$ git branch --set-upstream-to=origin/dev dev

你可能感兴趣的:(git分支)