关闭

Git工作区,暂存区和版本区

标签: git
235人阅读 评论(0) 收藏 举报
分类:

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在执行命令的时候,各个文件的情况和变动情况.

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:370621次
    • 积分:7497
    • 等级:
    • 排名:第2865名
    • 原创:381篇
    • 转载:2篇
    • 译文:0篇
    • 评论:72条
    最新评论