Git:思想及概念

Posted Storm_L

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Git:思想及概念相关的知识,希望对你有一定的参考价值。

Git与其他版本控制软件的差异及思想

直接记录快照,而非差异比较

    Git不保存这些前后变化的差异数据。实际上,Git 更像是把变化的文件作快照后,记录在一个微型的文件系统中。每次提交更新时,它会纵览一遍所有文件的指纹信息并对文件作一快照,然后保存一个指向这次快照的索引。为提高性能,若文件没有变化,Git 不会再次保存,而只对上次保存的快照作一链接。Git 的工作方式就如下图所示。

近乎所有操作都是本地执行

    在Git中的绝大多数操作都只需要访问本地文件和资源,不用连网。Git 不用跑到外面的服务器上去取数据回来,而直接从本地数据库读取后展示给你看。所以任何时候你都可以马上翻阅,无需等待。如果想要看当前版本的文件和一个月前的版本之间有何差异,Git 会取出一个月前的快照和当前文件作一次差异运算,而不用请求远程服务器来做这件事,或是把老版本的文件拉到本地来作比较。

时刻保持数据完整性

    在保存到 Git 之前,所有数据都要进行内容的校验和(checksum)计算,并将此结果作为数据的唯一标识和索引。换句话说,不可能在你修改了文件或目录之后,Git 一无所知。这项特性作为 Git 的设计哲学,建在整体架构的最底层。所以如果文件在传输时变得不完整,或者磁盘损坏导致文件数据缺失,Git 都能立即察觉。

基本概念

对于任何一个文件,在 Git 内都只有三种状态:

  已修改(modified):已修改表示修改了某个文件,但还没有提交保存。

  和已暂存(staged):把已修改的文件放在下次提交时要保存的清单中。

  已提交(committed):已提交表示该文件已经被安全地保存在本地数据库中了。

与其相对应的三个工作区域:

  工作目录:从项目中取出某个版本的所有文件和目录,用以开始后续工作的叫做工作目录。这些文件实际上都是从 Git 目录中的压缩对象数据库中根据某个版本提取出来的,接下来就可以在工作目录中对这些文件进行编辑。

  暂存区域:暂存区域只不过是个简单的文件,一般存放在.git/index中,所以我们把暂存区有时也叫作索引(index)。

  本地仓库:提交更新后,保存在暂存区域的文件快照永久转储到Git目录中。Git的对象库,实际位于".git/objects"目录下,里面包含了创建的各种对象及内容。当执行提交操作(git commit)时,暂存区的目录树写到版本库(对象库)中。

 

 

以上是关于Git:思想及概念的主要内容,如果未能解决你的问题,请参考以下文章

Git的思想和基本工作原理2

面向对象的基本概念

Spring的基本配置及概念

常见Git操作及关键知识点

RabbmitMQ-工作队列及相关概念

查找-概念性总结及代码示例