美文网首页
Git之——Git工作区、版本库和暂存区

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

作者: wsspace | 来源:发表于2018-11-29 17:43 被阅读0次

Git暂存区(stage)是比较难理解的部分,也是Git的特色之一,那么它和工作区与版本库之间的联系又是怎样的,在这之前,应该先记住如下点:

1、所说的版本库就是隐藏的.git目录。
2、文件 .git/index是记录了文件名、文件的状态信息(时间戳、文件长度等)等的文件索引的目录树。
3、Git 对象库(.git/objects)中保存的是文件索引中所指定的文件实体。

下面的图详细展示了三者之间的关系(图与相关说明均转自http://www.worldhello.net/2010/11/30/2166.html,这部分知识也可以再蒋鑫的《Git 权威指南》中找到)

git-stage.png

工作区、版本库、暂存区原理图

在这个图中,我们可以看到部分 Git 命令是如何影响工作区和暂存区(stage, index)的。
图中左侧为工作区,右侧为版本库。在版本库中标记为 "index" 的区域是暂存区(stage, index),标记为 "master" 的是 master 分支所代表的目录树。
图中我们可以看出此时 "HEAD" 实际是指向 master 分支的一个“游标”。所以图示的命令中出现 HEAD 的地方可以用 master 来替换。
图中的 objects 标识的区域为 Git 的对象库,实际位于 ".git/objects" 目录下,我们会在后面的章节重点介绍。
当对工作区修改(或新增)的文件执行 "git add" 命令时,暂存区的目录树被更新,同时工作区修改(或新增)的文件内容被写入到对象库中的一个新的对象中,而该对象的ID 被记录在暂存区的文件索引中。
当执行提交操作(git commit)时,暂存区的目录树写到版本库(对象库)中,master 分支会做相应的更新。即 master 指向的目录树就是提交时暂存区的目录树。
当执行 "git reset HEAD" 命令时,暂存区的目录树会被重写,被 master 分支指向的目录树所替换,但是工作区不受影响。
当执行 "git rm --cached <file>" 命令时,会直接从暂存区删除文件,工作区则不做出改变。
当执行 "git checkout ." 或者 "git checkout -- <file>" 命令时,会用暂存区全部或指定的文件替换工作区的文件。这个操作很危险,会清除工作区中未添加到暂存区的改动。
当执行 "git checkout HEAD ." 或者 "git checkout HEAD <file>" 命令时,会用 HEAD 指向的 master 分支中的全部或者部分文件替换暂存区和以及工作区中的文件。这个命令也是极具危险性的,因为不但会清除工作区中未提交的改动,也会清除暂存区中未提交的改 动。

--------------------------------------------------------------我是分割线14.4.13---------------------------------------------------------------------------------------------

下面是最近又看这部分内容的一个补充(学而时习之,不亦说乎?):
1、git status -s 参数,等同于--short,对git status的简化输出。
2、查看工作区、暂存区和版本库的目录树的方式。
工作区:正常的ls命令即可。
暂存区:git ls-files -s
版本库:git ls-tree HEAD

另一个很有用的命令:git clean -fd
(其中参数-f(force) -d(directory)),
作用:清除当前工作区中没有添加到版本库中的文件和目录。如
echo "test clean -fd" > test.txt
git status -s ---------> A test.txt
git clean -f ---------> Removing test.txt

3、.git/index与.git/objects
git status/git diff 等命令就是通过.git/index的记录进行的判断。index的内容是“包含文件索引”的目录树。但是文件的内容并没有在其中,而是在.git/objects中,文件索引建立了文件和对象库中对象实体之间的对应。

4、git中的有些操作只是操作了目录树,而没有涉及到对象库中的对象。
像git add 操作对象:目录树 + 对象库
而git commit操作对象:只有目录树

5、注意点:
git commit 可以加上 -a 参数,可以直接对本地所有变更的文件执行提交,简化了git add操作,相当于跳过了Git最大好处“暂存区”,所以不要使用这个命令。


原文:https://blog.csdn.net/u012150179/article/details/19409597

相关文章

  • 浅析git底层存储原理 2021-07-14

    git三区 git三大区:工作区、暂存区和git版本库 1.git版本库 先从git版本库说起,git版本库对应....

  • git及git常用命令

    了解Git: 下载git 版本库,暂存区与工作区: 版本库: 工作区: 暂存区: Git常用命令 将本地的某个文件...

  • GIT操作指南

    git分为工作区、暂存区和版本库 git init 初始化本地项目 git config git配置 工作区---...

  • git学习笔记

    推荐git bash\sourceTreegit 版本控制工具;工作流: 工作区-》暂存区-》版本库 1、git ...

  • GIT命令

    Git是目前世界上最先进的分布式版本控制系统 Git的安装 Git工作流程 Git 工作区、暂存区和版本库 工作区...

  • git 学习

    git 区域概念 git分为工作区(我们自己的file)和版本库这其中版本库又包含暂存区(Stage)和分支区(m...

  • Git分布式版本控制系统的使用二:Git 工作流程、工作区、暂存

    Git分布式版本控制系统的使用二:Git 工作流程、工作区、暂存区和版本库 一、Git 工作流程 参考菜鸟教程 ...

  • git

    git 1.git简介 workspace 工作区 index 暂存区 repository 本地版本库 remo...

  • git、gitlab+jenkens版本控制的安装、升级与灾备

    @[toc] 1. git仓库版本管理系统 环境 Git的工作区、暂存区和版本库的含义 工作区:就是你在电脑里能看...

  • git & Android Studio

    基础命令 工作区、暂存区和版本库 工作区有一个隐藏目录 .git 是 Git 的版本库,库里存了很多东西,其中最重...

网友评论

      本文标题:Git之——Git工作区、版本库和暂存区

      本文链接:https://www.haomeiwen.com/subject/algfcqtx.html