Git背后的设计理念
创始人
2024-06-02 06:18:50
0

首先要清楚Git版本管理中提交的概念。通过按行对比(line diff)将有差异的部分作为增量补丁,使用git add添加到暂存区里的每一个文件都会由按行对比得到他们的增量补丁,而使用git commit将暂存区里的所有文件的增量补丁合并起来存入仓库,这就是一次提交。

通常在提交时,会生成一个SHA-1 Hash值作为commitID。每个commitID中有40个十六进制数字。

就是该次提交在Git仓库中存储的内容和头信息的校验和。Git使用SHA-1并非为了保证安全性,而是为了保证数据的完整性,即可以保证很多年后重新检验某次提交时,一定是它多年前的状态,完全一模一样、完全值得信任。

按时间线依次排列的一组提交记录形成一个分支,比如默认分支master,也可以根据某种需要创建分支。

tag是某个提交的标签,比如发布1.0版本时的那次提交被专门打了个标签v1.0。标签就是别名,便于记忆和使用。

我们简要总结一下以上几个关键概念:

  •  按行对比是制作增量补丁的方法,即通过按行对比将有差异的部分制作成增量补丁。
  • 提交是存储到仓库里的一个版本,是整个项目的一个或多个文件的增量补丁合并起来形成的项目的增量补丁,是一次提交记录。每次提交都生成一个唯一的commitID。
  • 分支是按时间线依次排列的一组提交记录,理论上可以通过当前分支上最初的提交依次打补丁直到HEAD得到当前工作区里的源代码。
  • 标签是某次提交的commitID的别名。

合并操作常指将远程分支合并到本地master分支,或者某个本地分支合并到master分支。以下图为例,项目在A版本处开始分叉,形成了两个分支,分别提交了B、D、F和C、E、G,这时希望将这两个分支合并,只要将F与A有差异的部分放入工作区,此时C、E、G已经在工作区了,如果有冲突,解决冲突后就可以提交一个版本H,即完成了两个分支的合并。

简要总结一下,合并操作可以用一个公式来表示:H = A + (F - A) + (G - A),即F版本与A版本的差异,以及G版本与A版本的差异,与A合并起来,如果有冲突,解决冲突,形成一个新的版本H。

具体技术实现上,因为每一个版本都有上一个版本的“增量补丁”,只要将合并的分支里的B、D、F的增量补丁,合并到当前工作区G版本里,解决冲突后即可提交为H版本。

相关内容

热门资讯

过几个月老婆生孩子!帮忙给个名... 过几个月老婆生孩子!帮忙给个名字参考一下! 男孩女孩的名字都写出来!还不知道是男是女!姓吴吴浩学:博...
沪指7月开门红 银行与创新药板... 7月首个交易日,A股主要股指走势分化,银行板块强势发力,带动沪指收获7月开门红。截至收盘,上证指数报...
退休铁路警察用镜头“看见”成昆... 七个月、六十九座车站、十万张照片成昆铁路乃托铁马大桥。行走在成昆线上的罗兆进。沙马拉达隧道的卫士。 ...
“寻医成渝”大型主题报道重磅开... 探寻仁心医者足迹,解码行业典型案例  华西都市报讯(记者 周家夷)在健康中国战略持续推进下,成渝地区...
武当山和华山哪个更值得去 武当山和华山哪个更值得去华山一直都想去,不过一直没时间。武当山因为本人就是武汉人,所以端午去过,也还...
无锡华光环保能源集团:已回购近... 无锡华光环保能源集团股份有限公司于2025年7月2日发布股份回购进展公告,披露了自2025年4月15...
是便民驿站也是暖心港湾 转自:成都日报锦观记者探访成都燃气社区服务中心是便民驿站也是暖心港湾 本报讯 (成都日报锦观新...
会通新材料股份有限公司关于可转... 证券代码:688219 证券简称:会通股份 公告编号:2025-037转债代码:118028 转债...
广东冠豪高新技术股份有限公司第... 证券代码:600433 证券简称:冠豪高新 公告编号:2025-026广东冠豪高新技术股份有限公司...
跨省出门也有“医”靠   三湘都市报7月1日讯  湖南湖北一家亲,虽是不同的省份,却已经实现“异地就医区域互认”,为两省的...