集中式版本控制工具的文件管理机制:增量式版本控制
以文件变更列表的方式存储信息,这类系统将他们保存的信息看作是一组基本的文件和每个文件随时间逐步累积的差异。例如SVN
Git的文件管理机制:快照流
Git把数据看作是小型文件系统的一组快照。每次提交更新时Git都会对当前的全部文件制作一个快照并保存这个快照的索引。为了高效,如果文件没有修改,Git不在重新存储该文件,而是只保留一个连接指向之前存储的文件。所以Git的工作方式可以称之为快照流。
细节:
Git提交对象:将所有文件进行hash产生对应的哈希值,然后所以的目录的文件的哈希值构成一个树对象,包含每一个具体的文件,以及对应的哈希值。提交对象产生一个哈希值,对应的数据包含文件的树对象。
每个版本的联系是通过指针建立的联系,子版本parent指向父版本。
Git分支管理机制:本质就是指针的创建和移动
创建一个本地库产生的主干master指向当前的最新版本f30ab,f30ab由指针进行连接另外两个版本。此时如果 git branch -v testing 一个新的分支testing, 则testing创建一个指针指向f30ab(相比于复制数据,这种方法能够极大的提升效率和避免资源压力)
当进行分支切换时 git checkout testing ,HEAD指针指向了testing,就完成了分支的切换。
当testing产生新的版本时,testing指向新的版本,不会影响master,这样就完成了分支之间各自的操作。
此时再切换至master,HEAD指针重新指向master,就可以回到master的旧版本了。完全不涉及到文件的方面。
当master创建了一个新版本的时候,则产生了分支。testing与master分别指向不同的版本。