Git学习小记之分支原理

介绍

如果想要熟练使用 Git,没有分支理念是绝对行不通的,在用 Git 管理项目的时候,经常需要使用 commit 这个命令,那么这个 commit 到底是指什么呢?
按照官方的解释,这应该成为一个对象,它包含着一个指向暂存内容(被add的文件)快照的指针,包含本次提交的附属信息,比如说作者等等,指向父 commit 对象(如果被 merge 而成,可能有多个父 commit 对象)的指针。

举下面这个例子来分析:

git add README test.rb LICENSE
git commit -m 'initial commit of my project'

add:暂存操作会对文件计算校验和(SHA-1哈希字串),然后与当前版本的文件快照(用 blob 对象存储)一起存入到暂存区域中。

校验和(英语:Checksum)是冗余校验的一种形式。 它是通过错误检测方法,对经过空间(如通信)或者时间(如计算机存储)传送的数据的完整性进行检查的一种简单方法。

commit:正式建立提交对象前:Git 先计算出每一个子目录的校验和,然后在 Git 仓库中,将这些目录保存为树对象。

建立提交对象的过程主要日下:
携带相关提交信息,包含一个指向该树的指针,这样就代表如果将来需要,可以重现此次快照内容。
来看看现在仓库中有什么:
一个表示文件快照内容的 blob 对象,一个记录着目录树内容,以及其中各个文件具体对应哪个 blob 对象的索引 tree 对象。以及一个包含着指向索引 tree 对象,以及其他提交信息元数据的 commit 对象。
如图:

首次提交对象及其树结构

如果我们做一些修改,再次进行提交,此时就开始发生变化, commit 提交对象会再多包含一个指向上次 commit 提交对象的指针。

如官方图:

Paste_Image.png

分支

有了上面的准备知识,我们可以开始学习分支了。先回顾现在的提交模型:
每次提交都会生成一个新的 commit 对象,还有一个指向上次提交,也就是父对象的指针。
Git 中的分支的本质上就仅仅是指向commit 对象的指针,如果 Git 分支这个指针指向某次 commit,它就拥有了此次 commit 对象,这意味着很多。
Git中默认的都会有一个分支,这个分支叫做 master,若干次提交之后,实际上有一个最新的 commit 对象,以及指向这个对象的master分支,伴随着每次提交,master 对象要做的就是不断指向新 commit 对象。

创建分支

现在有些清晰了,其实在 Git 中创建分支,就是创建一个指向某次commit 对象的可变指针,我们来新建一个开发分支:

git branch testing

git如何做到分支互不影响

按照之前的理解,在当前 commit 上,会有一个指针依附它,这个指针就是 testing 分支指针。
我们知道在我们开发中,如果建立了分支,就意味着互不影响,按照上面说的, 轻松建立了分支。

Paste_Image.png

Git如何辨别我们工作的分支

既然只要新建了分支,我们的开发就和其他分支互不影响了,Git 是如何分辨我们到底在哪个分支上工作呢?
其实答案比较简单,Git 包含着一个名为 HEAD 的特别指针,在Git中,它会指向你正在工作的本地分支指针上(将 HEAD 想象成当前分支指针的别名)。
上面使用git branch创建了一个分支,此时仅仅建立了一个分支指针,HEAD 指针未出现过移动,依然指向之前的 master 。要切换 HEAD 指针的指向,使用 切糕 命令。

git checkout testing

此时 HEAD 指向之前新建的 testing 分支,但是 master 分支依然指向 checkout 时所在的那个 commit 对象。这个的确太有意思了。。
所谓分支,从当前分支建立(默认是 master 分支),使用切糕命令,本质上做的就是切换 HEAD 对象的指针的位置,并且把当前工作目录上的文件替换成分支所指向的快照内容。

此时如果进行一次 commit ,那么最新的 commit 对象指向上次的提交,分支指针指向本次 commitHEAD 指针又指向本次分支。

继续再进行切换

git checkout master

此时就到了重点,HEAD 指针指向 master 分支,master 分支指针指向某次 commit ,同时 checkout 还会将当前工作目录中的文件替换成 master 分支所指向的快照内容(实际上在切糕命令执行时,我们完全可以认为快照会不断的改变,也由于此时指向的是快照内容,所以切糕之前未暂存的文件是无法经过切换来恢复了)。

分叉出现了

我们修改 master 分支上面的文件,并且创建提交。由于我们之前已经创建过一次分支,并且提交过一次,然后才回到 master 分支开发的,就会造成这样一种情况,这两次分支虽然指向的 commit 对象的父对象个数是相同的,但是他们在此时出现了分歧,从 master 分支开始,他们有不同的流向了,此时也就开始出现分叉了,我们可以不断的切换分支,等待合适的时机,将它们合并到一起。
如上所见,在各个分支中无拘无束的开发,不断的切换,仅仅只需要branch ,切糕两个命令即可。

总结

所谓分支,就是一个指向某个对象的指针,这个指针是一个校验和文件(40 个字符长度 SHA-1 字串),所以新建和销毁指针是非常廉价的事情,也就解释了为什么切换起来那么快,那么方便了。Git鼓励频繁的使用分支。

待解决的问题?

  1. 所谓校验和文件是什么?是一个独一无二的字符串?为什么又说它是指针呢?这个指针是根据什么生成的?既然它指向commit文件,那么是不是根据commit文件计算出的呢,commit对象之间是相连的,那么如果通过commit文件计算出的,那么应该说的通。

  2. 所谓合并,到底是做了什么,开启了一个新分支?貌似并没有,因为开发过程只有一个master,不会因为合并不断的建立新分支。

  3. 合并之后会有一次commit,此时的commit对象就有两个父对象了,好奇的commit历史里面在合并之前只有master对象?还是里面乱乱的,根据时间会出现很多分支的commit对象,哈哈,等本少年去试试,不过前者的可能性貌似大些吧。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,816评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,729评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,300评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,780评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,890评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,084评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,151评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,912评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,355评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,666评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,809评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,504评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,150评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,121评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,628评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,724评论 2 351

推荐阅读更多精彩内容

  • Git是目前最流行的版本管理系统,也是最先进的分布式版本控制系统(distributed version cont...
    pro648阅读 5,684评论 1 17
  • 从2011年开始,2012年4月15日在一起,到2016年的现在,你陪我度过的五年时光。 我还记着那天小卖店过期的...
    Emotiona始于初见阅读 386评论 0 0
  • 谁可以预言明天,谁能保证一辈子不让热的心冷却,而有些事情会改变像习惯和季节,但属于我们的故事不想有终点。你能不能许...
    雨韵墨香阅读 331评论 0 0