Git工作区,暂存区和版本区
基本概念
这里出现了三个名词:工作区,暂存区,版本库.
工作区:你工作的地方,你在哪里工作呢?肯定是你的电脑上,那么工作区就是你在电脑里能看到的目录.
暂存区:英文名叫stage或者index.听名字就知道是暂时的,不是永久的,数据会经常的发生变化,这个区域一般存放在’git目录’下的index文件(.git/index)中,我们把暂存区有时候也叫做索引(index).
版本库:工作区中有一个隐藏目录.git,这个不算工作区,而是Git的版本库.
简单说一下这个图,图中的左侧为工作区,右侧为版本库.在版本库中标记为’index’的区域就是暂存区(stage或者index),标记为’master’的是master分支所代表的目录树.
图中我们可以看出此时”HEAD”实际是指向master分支的一个’游标’.所以图示的命令中出现HEAD的地方可以用master来替换.
图中objects标识的区域为Git的对象库,实际位于’.git/object’目录下,里面包含了创建的各种对象以及内容.
当对工作区修改(或新增)的文件执行”git add”命令时,暂存区的目录树被更新,同时工作区修改(或新增)的文件内容被写入到对象库中的一个新的对象中,而该对象的ID被记录在暂存区的文件索引中.
当执行提交操作(git commit)时,暂存区的目录树写到版本库(对象库)中,master分支会做相应的更新.即master指向的目录树就是提交暂存区的目录树.
当执行’git reset HEAD’命令时,暂存区的目录树会被重写,被master分支指向的目录树所替换,但是工作区不受影响.
当执行’git rm --cached <file>’命令时,会直接从暂存区删除文件,工作区则不会做出改变.
当执行’git checkout HEAD’或者’git checkout HEAD <file>’命令时,会用HEAD指向的master分支中的全部或者部分文件替换缓存区以及工作区中的文件.这个命令也是极具危险性的,因为不但会清楚工作中未提交的改动,也会清楚暂存区中未提交的改动.
这里主要的是说一些Git在执行命令的时候,各个文件的情况和变动情况.