Git分支

分支其实就是一个指向一个commit id的引用,而工作区下面的.git/HEAD 文件里的内容就是当前所处在的分支的引用, 通过改变这个文件的指向的分支从而切换分支!而.git/refs/heads/ 目录下面的每一个文件都对应一个分支,文件名就是分支名(例如:在master分支上提交一次,那么这个分支对应的文件目录就是.git/refs/heads/master)。下面我们用图演示一番。

这里写图片描述
首先初始化一个本地版本库,然后在master分支进行第一次提交(因为不提交一次,.git/refs/heads/ 下面就不会产生master文件 )。
然后查看此次提交的commit id为1a05d46cf1795bca209ad22af98d08aa14eb4cf7。下面我们看下master分支的指向。

这里写图片描述

master里面的内容就是刚才我们提交的commit id。上面说.git/HEAD 文件里面记录的时候当前指向的分支,现在我们来查看这个文件来看看是否如此。

这里写图片描述

事实果然如上面所说,此文件指向的就是.git/refs/heads/master 文件(因为是从工作区访问这个文件所以需要加上.git/)。

这里写图片描述

上面关系图描述它们之间的关系。

这里写图片描述

现在我们进行第二提交,然后查看提交commit id为ee5639547e82ba99f95942ffec229d97428821a7,现在第一次提交是第二次提交的父提交。而master分支会指向最新的提交也就是第二次提交。由于我们没有切换分支HEAD指向没变。

这里写图片描述

执行第二次提交之后的关系图。下面我们来看下分支之间的关系是怎么样的。

这里写图片描述

这里使用git checkout -b 命令创建一个名叫feature的分支然后切换到此分支上。然后查看分支对应的分支文件里面提交commit id(这里由是在master分支上创建的一个新分支,因此这个新分支会指向master分支所指向的commit id)。

这里写图片描述

创建feature分支之后的关系图,由于切换了分支所以HEAD的指向也改变了。

参考

《Pro Git》


如此文章有不对地方请多多指正!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值