【Git】第四篇:基本操作(理解工作区、暂存区、版本库)

Git 工作区、暂存区和版本库

  • 工作区:就是我们创建的本地仓库所在的目录
  • 暂存区: stage或index,一般放在.git(可隐藏文件)目录下的index文件(.git/index)中,所以我们把暂存区有时候也叫做索引(index)
  • 版本库 :工作区有一个隐藏目录.git,所说的版本库就是隐藏的.git目录。

下面的图详细展示了三者之间的关系:

  1. 文件 .git/index是记录了文件名、文件的状态信息(时间戳、文件长度等)等的文件索引的目录树。
  2. Git 对象库(.git/objects)中保存的是文件索引中所指定的文件实体。
  3. 图中左侧为工作区 ,右侧为版本库 。在版本库中标记为 "index " 的区域是暂存区(stage, index)或者索引区 ,标记为 "master" 的是 master 分支所代表的目录树。
  4. 图中我们可以看出此时 "HEAD" 实际是指向 master 分支的一个"游标"。所以图示的命令中出现 HEAD 的地方可以用 master 来替换。
  5. 当对工作区修改(新增、修改、删除)的文件执行 "git add" 命令时,暂存区的目录树被更新,同时工作区修改(或新增)的文件内容被写入到对象库(objects)中的一个新的对象中,而该对象的ID 被记录在暂存区的文件索引(index)中。
  6. 当执行提交操作(git commit)时,暂存区的目录树写到版本库中的对象库(objects)中,master 分支会做相应的更新。即 master 指向的目录树就是提交时暂存区的目录树。
相关推荐
wang_book24 分钟前
Gitlab学习(007 gitlab项目操作)
java·运维·git·学习·spring·gitlab
不是笨小孩i4 小时前
Git常用指令
大数据·git·elasticsearch
救救孩子把4 小时前
mac中git操作账号的删除
git·macos
汀、人工智能5 小时前
报错error: RPC failed,curl 16 Error in the HTTP2 framing layer解决方法
网络·git·网络协议·rpc
Eoneanyna7 小时前
QT设置git仓库
开发语言·git·qt
+码农快讯+7 小时前
Git入门学习(1)
git·学习·elasticsearch
VaporGas11 小时前
idea集成和使用Git指南
java·git·intellij-idea
无名之逆11 小时前
计算机专业的就业方向
java·开发语言·c++·人工智能·git·考研·面试
大广-全栈开发12 小时前
centos 7 安装gitlab
linux·git·centos
zhangphil12 小时前
git删除本地分支报错:error: the branch ‘xxx‘ is not fully merged
git