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版本。

相关内容

热门资讯

你的晚安是我的早安是什么歌曲 你的晚安是我的早安是什么歌曲苏天伦《你的早安是我的晚安》“你的晚安是我的早安”是单小源的歌曲《东京遇...
积极进取的小故事 积极进取的小故事现代的普通人,不要名人的。不能与别人重复,尽快回答   啄木鸟的故事       啄...
熊出没之探险日记3什么时候播出... 熊出没之探险日记3什么时候播出?熊出没之探险日记3,春节前播放。熊出没只是探险日记三2020年5月4...
谁知道所有有关“七”的歌?拜托... 谁知道所有有关“七”的歌?拜托了各位 谢谢就是歌曲名里有“七”这个字的!谢谢七月七迅谈日晴 看我七十...
求一本小说 女主穿越了三次 每... 求一本小说 女主穿越了三次 每次都在福临身边 后来怀孕了孩子被打掉了那个 女主叫什么雯?那个女主就是...
如果记忆不说话,流年也会开出花... 如果记忆不说话,流年也会开出花的基本信息书 名:《如果记忆不弯饥好说话,流年也会开出花》埋铅 作 者...
你好,旧时光漫画版在哪里可以看... 你好,旧时光漫画版在哪里可以看?暂时在绘心上连载
一首英文歌,男的组合唱的,MV... 一首英文歌,男的组合唱的,MV是一个婚礼的过程。求歌名。是不是darin的can'tstoplove...
为什么很多人喜欢用胶片相机? 为什么很多人喜欢用胶片相机?有一种情怀叫做“怀旧“吧,现在数码相机越来越普遍了,已经到了”全民摄影“...
女主先爱上男主,男主却不喜欢女... 女主先爱上男主,男主却不喜欢女主或者是另有所爱,最后女主男主还是在一起的穿越小说。有木有再生缘:我的...
爱情失恋伤感句子 爱情失恋伤感句子越是美好的从前,越幸福的曾经,现在只能带来锥心的疼痛,痛到撕心裂肺,肝肠寸断,终于痛...
24岁穿这个会不会显老 24岁穿这个会不会显老有点显老,这个颜色款式,颜色有点暗,没有活力,属于那种气质佳,长得高雅的女人,...
哈尔的移动城堡英语版 哈尔的移动城堡英语版可以发给我吗度盘~请查收~
秦时明月之万里长城什么时候播 秦时明月之万里长城什么时候播据说是今年暑假开播别急,官网什么的信他你就输了,12年之前底应该会出,杭...
孩子会得抽动症吗? 孩子会得抽动症吗?我天生的气性比较大,有时跟别人斗嘴时候就会手脚哆嗦,麻木,我问一下这是不是抽动症就...
亨德尔一生为音乐献出了怎样的贡... 亨德尔一生为音乐献出了怎样的贡献?亨德尔一生写了歌剧41部,清唱剧21部,以及大量的管乐器与弦乐器的...
礼仪起源和发展的经典故事? 礼仪起源和发展的经典故事?一、礼仪的起源;1、天神生礼仪;2、礼为天地人的统一体;3、礼产生于人的自...
描写桂林山水的句子有哪些? 描写桂林山水的句子有哪些?天下风光数桂林有杨万里的“梅花五岭八桂林,青罗带绕碧玉簪”;有邹应龙的“无...
避免与强敌正面对决的成语 避免与强敌正面对决的成语避免与强敌正面对决的成语避实就虚 【近义】避重就轻、避难就易、声东击西【反义...
多愁善感类的成语 多愁善感类的成语心细如发【解释】:极言小心谨慎,考虑周密。亦作“心细于发”。【出自】:吴梅《题天香石...