版本管理工具一般都会有分支机制。分支简单来讲就是将主版本(主分支)开出一条支线,支线上的项目被修改不影响主版本的内容,两者级别是平行的,等到两个分支(主分支和其它分支)达到一个可以合并的点,就可以将其中一个分支的内容合并到主分支上。如图:
一般构建分支,是为了模块化开发,一些开发人员开发分支A上的功能,一些开发人员开发分支B的功能,待两组开发人员都开发完成,就可以将两个分支合并,这样就相当于在一个时间内同时完成了两个功能,而在开发过程中两个分支互相不影响。
还有一种情况就是生产、测试与开发的分支,一般就是生产是一个主分支,测试和开发是另外两个分支,等到开发环境没有问题之后,代码合并到测试分支,而测试分支经过测试之后完全没有问题后,就合并到生产分支上。
下面我们先来讲一下Git管理分支的方法。
在Git中,HEAD是用来指向目前提交的分支,相当于一个指针。当我们创建新的版本库之后,会有一个唯一的主分支master,指向当前版本库的时间线。此时HEAD会默认指向master分支,我们提交的代码只会改变master主分支的时间线:
当我们创建分支的时候,其实就是创建了一个新的指针,指向当前最新的时间线,而切换分支就是将HEAD的指向更换即可:
如果此时分支branch提交了代码,那么此时它的时间线向前推进:
这时候如果想将分支branch与master主分支合并,并切换回主分支。其实很简单,首先将master的指针指向branch的指针指向的位置,然后将HEAD指向master即可:
如果不需要分支branch了,就直接删除branch的指针即可:
Git中的分支管理就是以上的机制。
下面我们学习Git分支管理的具体操作。
首先在我们之前的Git本地库文件夹右键选择“Bash Here”,打开Git控制台:
使用“git branch 分支名”创建分支,而“git checkout 分支名”是切换到分支。如果在“checkout”后面加“-b”代表切换到该分支。所以“git checkout -b 分支名”就是创建并切换到分支。我们这里创建“branchTest”分支,并切换到该分支:
上面创建并切换完成之后,使用“git branch”可以查看当前分支。可以看到有两个分支,一个主分支master以及刚刚创建并目前指向的branchTest分支(当前分支会标记星号“*”)。
下面我们对项目中的README.md文件进行修改,添加一句“Success Create A New Branch”:
然后我们将文件添加至暂存区,然后提交到本地库:
分支branchTest的修改完成后,我们可以将分支切换回master:
此时去查看README.md是看不到变化的,因为此时master的时间线与branchTest分支的时间线不一样:
现在只需将branchTest分支内容合并到master分支上即可,使用“git merge 要合并的分支”即可:
现在去观察README.md文件,发现已经将修改合并:
上面我们采用的是“快速合并”的方式,你可以看到执行合并命令后的“Fast-forward”语句。“快速合并”就是直接将master指向branchTest的当前提交,所以速度很快。
合并之后,如果不需要branchTest分支,就可以直接删除该分支,使用“git branch -d 分支名”即可:
可以看到删除分支后,就只剩下我们的主分支master了、
一般构建分支,是为了模块化开发,一些开发人员开发分支A上的功能,一些开发人员开发分支B的功能,待两组开发人员都开发完成,就可以将两个分支合并,这样就相当于在一个时间内同时完成了两个功能,而在开发过程中两个分支互相不影响。
还有一种情况就是生产、测试与开发的分支,一般就是生产是一个主分支,测试和开发是另外两个分支,等到开发环境没有问题之后,代码合并到测试分支,而测试分支经过测试之后完全没有问题后,就合并到生产分支上。
下面我们先来讲一下Git管理分支的方法。
在Git中,HEAD是用来指向目前提交的分支,相当于一个指针。当我们创建新的版本库之后,会有一个唯一的主分支master,指向当前版本库的时间线。此时HEAD会默认指向master分支,我们提交的代码只会改变master主分支的时间线:
当我们创建分支的时候,其实就是创建了一个新的指针,指向当前最新的时间线,而切换分支就是将HEAD的指向更换即可:
如果此时分支branch提交了代码,那么此时它的时间线向前推进:
这时候如果想将分支branch与master主分支合并,并切换回主分支。其实很简单,首先将master的指针指向branch的指针指向的位置,然后将HEAD指向master即可:
如果不需要分支branch了,就直接删除branch的指针即可:
Git中的分支管理就是以上的机制。
下面我们学习Git分支管理的具体操作。
首先在我们之前的Git本地库文件夹右键选择“Bash Here”,打开Git控制台:
使用“git branch 分支名”创建分支,而“git checkout 分支名”是切换到分支。如果在“checkout”后面加“-b”代表切换到该分支。所以“git checkout -b 分支名”就是创建并切换到分支。我们这里创建“branchTest”分支,并切换到该分支:
上面创建并切换完成之后,使用“git branch”可以查看当前分支。可以看到有两个分支,一个主分支master以及刚刚创建并目前指向的branchTest分支(当前分支会标记星号“*”)。
下面我们对项目中的README.md文件进行修改,添加一句“Success Create A New Branch”:
然后我们将文件添加至暂存区,然后提交到本地库:
分支branchTest的修改完成后,我们可以将分支切换回master:
此时去查看README.md是看不到变化的,因为此时master的时间线与branchTest分支的时间线不一样:
现在只需将branchTest分支内容合并到master分支上即可,使用“git merge 要合并的分支”即可:
现在去观察README.md文件,发现已经将修改合并:
上面我们采用的是“快速合并”的方式,你可以看到执行合并命令后的“Fast-forward”语句。“快速合并”就是直接将master指向branchTest的当前提交,所以速度很快。
合并之后,如果不需要branchTest分支,就可以直接删除该分支,使用“git branch -d 分支名”即可:
可以看到删除分支后,就只剩下我们的主分支master了、
关于分支管理的常用知识,在后续的总结文章中会继续向大家介绍。
转载请注明出处:http://blog.csdn.net/acmman/article/details/77720930