【Git】5.分支管理

版本管理工具一般都会有分支机制。分支简单来讲就是将主版本(主分支)开出一条支线,支线上的项目被修改不影响主版本的内容,两者级别是平行的,等到两个分支(主分支和其它分支)达到一个可以合并的点,就可以将其中一个分支的内容合并到主分支上。如图:

一般构建分支,是为了模块化开发,一些开发人员开发分支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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

光仔December

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值