Git的工作机制

Git 的核心工作机制

🔍 差异存储(Delta Storage)

Git 会比较文件的变化,只存储改变的部分,而不是整个文件的完整副本。

举个例子:

假设你有一个 100KB 的文件,第一次提交时 Git 会完整保存。

第二次只修改了一行代码,Git 只会存储:

  • "第50行,删除了 'old code',新增了 'new code'"
  • 而不是重新保存整个 100KB 的文件

📦 高效的对象存储

Git 使用四种核心对象:

  1. Blob:存储文件内容
  2. Tree:存储目录结构
  3. Commit:存储提交信息(作者、时间、父提交等)
  4. Tag:存储标签信息

🔄 工作原理

复制代码
第一次提交:文件A(版本1) → Blob对象A1
第二次提交:文件A(版本2) → 比较差异 → 存储差异 + 指向A1的引用
第三次提交:文件A(版本3) → 比较差异 → 存储差异 + 指向A2的引用

验证你的理解

你可以通过以下命令看到 Git 的智能存储:

bash 复制代码
# 查看某个文件的历史变化
git log -p 文件名

# 查看存储效率
git count-objects -v

为什么这样设计?

  1. 节省空间:只存储变化,大大减少仓库体积
  2. 快速比较:可以轻松比较任意两个版本之间的差异
  3. 完整历史:通过链式引用,可以重建任何历史版本
  4. 分支高效:创建分支几乎不占额外空间

例外情况

对于二进制文件(如图片、编译产物),Git 无法进行差异分析,所以会完整存储每个版本。这就是为什么建议不要在 Git 中存放大型二进制文件。

你的理解完全正确! Git 是一个智能的版本控制系统,而不是简单的文件备份工具。这正是它比直接复制文件夹高效得多的原因。

相关推荐
сокол1 小时前
【网安-等保评测-基础记录】网络安全等级保护2.0 详解(定级、备案、测评、整改一站式指南)
网络·笔记·网络安全·云计算
ahccqw2 小时前
CAN总线通信入门及实例代码(stm32f4系列)
stm32·单片机·嵌入式硬件
qeen874 小时前
【算法笔记】模拟与高精度加减乘除
c++·笔记·算法·高精度·模拟
云攀登者-望正茂4 小时前
将 develop 分支拉取到特性分支时解决合并污染问题
git
U盘失踪了4 小时前
什么是B/S 架构和 C/S 架构
笔记
像一只黄油飞5 小时前
第二章-02-注释
笔记·python·学习·零基础
charlie1145141915 小时前
嵌入式现代C++工程实践——第14篇:第二次重构 —— 模板登场,编译时绑定端口和引脚
开发语言·c++·stm32·安全·重构
xiebingsuccess5 小时前
ThingsPanel IoT Platform 学习笔记
笔记·学习
是上好佳佳佳呀5 小时前
【前端(七)】CSS3 核心属性笔记:单位、背景、盒子模型与文本换行
前端·笔记·css3
雾岛听蓝5 小时前
Qt 输入与多元素控件详解
开发语言·经验分享·笔记·qt