git工作区、暂存区和版本库之间联系
2017-02-10 10:16
351 查看
三者之间的联系,我本人结合网上的一些经验总结如下,如图1所示:
图 1
我们打开 项目文件夹,整个项目就是我们的工作区(如图2所示):
图 2
版本库在哪里呢?就是这个".git"(如图3所示):
图 3
打开".git"文件夹之后(如图4所示):
图 4
图中画圈的的两个,一个index对应的是暂存区的目录树,包含了文件名和文件的状态信息,但是文件的内容并不存在放此处,而是存放在"objects"文件夹里;head对应的是版本库的目录树,也包含了文件名和文件的状态信息,同样的文件的内容也是保存在"objects"文件夹里。
当我们运行"git add"命令的时候,本地项目中所做的的修改会首先提交到暂存区里,这个时候暂存区的目录树被更新,产生一个ID,这个ID对应着修改的文件内容(就好比酒店的房间和房卡的联系),修改的文件内容是保存在"objects"文件夹里
当我们运行"git commit"命令的号死后,暂存区的目录树会传送给工作区,保存在"HEAD"文件里面,此时这个这个目录树对应的文件还是刚才已经提交到"objects"文件夹里的内容
大致的流程如下(如图5和图6):
图 5
图 6
图 1
我们打开 项目文件夹,整个项目就是我们的工作区(如图2所示):
图 2
版本库在哪里呢?就是这个".git"(如图3所示):
图 3
打开".git"文件夹之后(如图4所示):
图 4
图中画圈的的两个,一个index对应的是暂存区的目录树,包含了文件名和文件的状态信息,但是文件的内容并不存在放此处,而是存放在"objects"文件夹里;head对应的是版本库的目录树,也包含了文件名和文件的状态信息,同样的文件的内容也是保存在"objects"文件夹里。
当我们运行"git add"命令的时候,本地项目中所做的的修改会首先提交到暂存区里,这个时候暂存区的目录树被更新,产生一个ID,这个ID对应着修改的文件内容(就好比酒店的房间和房卡的联系),修改的文件内容是保存在"objects"文件夹里
当我们运行"git commit"命令的号死后,暂存区的目录树会传送给工作区,保存在"HEAD"文件里面,此时这个这个目录树对应的文件还是刚才已经提交到"objects"文件夹里的内容
大致的流程如下(如图5和图6):
图 5
图 6
相关文章推荐
- git工作区、暂存区、版本库之间的关系
- git工作区、暂存区、版本库之间的关系
- git 工作区、暂存区、版本库之间的关系案例
- Git的工作区、暂存区和版本库之间的关系及其互操作
- Git的工作区、暂存区和版本库之间的关系及其互操作
- Git的工作区、暂存区和版本库之间的关系及其互操作
- git工作区、暂存区、版本库之间的关系
- Git之——Git工作区、版本库和暂存区
- 工作区 暂存区 版本库之间的关系
- git中的版本库,暂存区和工作区
- 【web前端自动化工作环境配置】6. 版本控制工具git与githup的区别与联系以及git的基本用法
- [git]入门-工作区、暂存区、版本库
- Git 菜鸟变大神 (三) 工作区、暂存区、版本库之间的关系案例
- git工作流程、Git 工作区、暂存区和版本库
- Git之工作区、版本库、暂存区
- Git 教程之工作区、暂存区和版本库详解
- Git 菜鸟变大神 (三) 工作区、暂存区、版本库之间的关系案例
- git版本库的工作区 暂存区
- Git工作区、暂存区和本地版本库关系