见证大牛成长之路的专栏

对于程序员来说,代码就是生命!

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

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

阅读更多
文章标签: git
个人分类: Git
上一篇Git工作流程
下一篇Git创建仓库
想对作者说点什么? 我来说一句

Git使用教程

2018年07月06日 122KB 下载

git的最新包

2018年07月05日 162B 下载

git使用手册

2018年05月09日 1.04MB 下载

没有更多推荐了,返回首页

关闭
关闭