您的位置:首页 > 其它

Git 工作区和暂存区

2017-02-15 13:32 211 查看
我们先来理解下Git 工作区、暂存区和版本库概念,前边我们简单介绍过,今天在温习一遍:
工作区:就是你在电脑里能看到的目录,比如 work文件夹 就是个工作区。
暂存区:stage, 或index。一般存放在 工作区的隐藏目录.git 下的index文件(.git/index)中,所以我们把暂存区有时也叫作索引(index)。
版本库:工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。

不要以为.git是个普通文件,这里包含了最重要的暂存区,暂存区也是git与svn最大的不同之处的一个方面。版本库里还有Git默认

创建的master分支 (你可以回忆回忆你是否自己主动创建过master分支),以及指向这个master分支的指针HEAD。

下面这个图展示了工作区、版本库中的暂存区和版本库之间的关系:



图中左侧为工作区,右侧为版本库。在版本库中标记为 "index" 的区域是暂存区(stage, index),标记为 "master" 的

是 master 分支所代表的目录树。

图中我们可以看出此时 "HEAD" 实际是指向 master 分支的一个指针或游标。

图中的 objects 标识的区域为 Git 的对象库,实际位于 ".git/objects" 目录下,Git把你的数据对象保存于此,

Git就是利用SHA1 哈希值,进而查看哈希链的这一点保证数据完整性,那里不到你的正常文件名,

而只看到ID,通过ID作为文件名加上文件锁和时间戳技巧,Git把任意一个原始的文件系统转换为稳定而高效的数据库。

我们向版本库添加文件的时候,一般会操作 “git add” 和“git commit”两个步骤,

下边我们就这两个步骤,具体分析版本库的内部变化:

1.git add 命令:当工作区修改文件或新增时,执行此命令,讲文件修改添加到暂存区。

暂存区的目录树被更新,同时工作区修改(或新增)的文件内容被写入到对象库中的一个新的对象中,而该对象的ID被记录在暂存区的文件索引中



2.git commit 命令:把暂存区的内容提交到当前分支。暂存区的目录树写到版本库(对象库)中,

master 分支会做相应的更新。即 master 指向的目录树就是提交时暂存区的目录树。

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息