git对象

1、对象类型

git对象库是Git版本库实现的核心,它包含了原始数据文件和所有的日志信息、作者信息、日期,已经其他用来重建项目任意版本或者分支的信息。位于.git/objects目录下。

├── HEAD
├── branches
├── config
├── description
├── hooks
│ ├── pre-commit.sample
│ ├── pre-push.sample
│ └── ...
├── info
│ └── exclude
├── objects
│ ├── info
│ └── pack
└── refs
 ├── heads
 └── tags

git对象库中有四种类型:块(blob)、目录树(tree)、提交(commit)、标签(tag)。这四种原子对象构成了Git高层数据结构的基础。
git对象的寻址使用40位的16进制数表示,也就是SHA1或者散列码,例如7f8aacaddffe009fff75b81187527c35a51f3eac。为了管理方便在文件系统中前两位作为文件夹的名字,后38为作为文件名字。
你可能感觉用40位作为git对象的寻址ID,可能会存在不同的内容但是散列码相同的情况,你的感觉是正确的,但是这种情况出现的概率肯定可以忽略不计了。
其对象的关系如下:

git对象

git对象

2、blob 块

blob对象存储文件的时间内容,实际为工作空间的文件内容。具体为对文件内容使用zlib算法压缩,然后对得到的字节取hash算法。因此相同的文件内容,得到的blob对象肯定是相同的。
示例:

git init temp              -----初始化一个空的git仓库
cd temp
echo "Welcome to git">hello.txt
git add hello.txt             ------添加到暂存器

此时我们查看.git/objects的目录如下:

git对象

此时我们可以通过git cat-file命令查看git对象的内容。注意cat-file命令可以查看所有的git对象。这个命令可以查看所有的git对象。

git cat-file -p b08a2810d8a4542f350f650435f506c6c81ca9b2

Welcome to git

由于git对文件内容使用压缩然后对内容取hash作为文件名的特性,因此不管文件系统中同样文件内容有几份,在git对象中都仅仅存一份。

3. 目录树 tree

git目录树对象映射操作系统中工作空间的目录,不同的是工作空间的目录下是文件和文件夹的集合,而目录树对象则为blob对象和目录树对象的集合。

mkdir src
cd src
cp ../hello.txt hello.txt
git add hello.txt
git write-tree   -----git的内部命令,commit命令基本等于write-tree 和commit-tree命令

此时我们使用write-tree命令返回的hash值使用cat命令

git对象

从图中可以看出内容相同的文件,blob是相同的,命令树tree对象是对应文件系统的文件夹的一个映射。

4.commit提交

提交是我们使用git的时候经常的动作,每一个提交都执行了一个目录树对象。同时提交也有一个或者多个父提交。我们现在使用commit-tree命令来关联目录树对象吧(一般使用commit命令来自动创建树对象和关联父提交)。
我们可以使用git $command --help来查看命令的资料文档,例如git commit --help 、git pull --help

 git commit-tree 5657a3b1d1454667d51f8c64c1fe9830276cdcea -m "1 commit"         ----初次提交所以没有指定父提交
7df70363051681bdd078b6a1a3fc9fe3d1595325           ----返回commit对象的HASH值

git cat-file -p 7df70363051681bdd078b6a1a3fc9fe3d1595325
tree 5657a3b1d1454667d51f8c64c1fe9830276cdcea
author xxxxxxx <xxxx@163.com> 1516538936 +0800
committer xxxx <xxxx@163.com> 1516538936 +0800

1 commit

注意此时当我们使用git log命令并不会显示刚刚的提交,需要使用 git merge 7df70363051681bdd078b6a1a3fc9fe3d1595325命令合并到master分支。可以看出git commit命令基本等于write-tree commit-tree merge命令。

现在我们修改工作空间中的hello.txt命令,然后提交查看目录树的内容。

git对象


注意看tree对象和第一次提交队对应的tree对象相同,都是e15a40c68bd15301b60d21c204a5e7a87d62d8a1,而本身我们也没有修改其文件夹下面的任何内容。而blob对象32690ead83f3b77ad763e9e2c2e60ce3706cf117的内容是两行,说明git对象内部提交指定的tree对象是工作空间的一个快照,而不是存储的增量(否则内容就是刚刚添加的一行了)。

5.标签 tag

标签仅仅是一个提交的快照,而且不允许修改其内容。

$ git tag 1.0
$ git cat-file -p 1.0
tree f935b24b9a688ba5050fda30d70801c9092caeaa
parent 7df70363051681bdd078b6a1a3fc9fe3d1595325
author xxx <xxx@163.com> 1516542403 +0800
committer xxx <xxx@163.com> 1516542403 +0800

2 commit

6.F&Q

1.git的编码方式

git的blob对象使用字节流进行存储,因此不存在编码问题。
对于目录树对象对应的路径、commit对应的message注释,默认都使用UTF-8编码。

如果想修改编码格式请参照(除非有特别的理由):https://git-scm.com/docs/git-commit/1.8.0.1#_discussion

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Git安装和使用 Git安装和使用 刚开始用git的小白适用,,转自http://www.cnblogs.com/qijunjun/p/7137207.html 实际项目开发中,我们经常会用一些版本控制器来托管自己的代码,今天就来总结下Git的相关用法,废话不多说,直接开写。 目的:通过Git管理g
fatal: remote origin already exists.解决方法 第一个问题git remote add origin**************fatal: remote origin already exists.(报错远程起源已经存在。)上网查了下,有很多小白遇到过这个问题,以
git常用命令(二)查看历史记录 git log [--pretty=oneline] [ --oneline] / reflog Eniac-W 于 2020-10-18 18:12:38 发布 2368 收藏 3分类专栏: git 文章标签: git版权 git专栏收录该内容10 篇文章0 订阅
git之如何把本地文件上传到远程仓库的指定位置 git专栏收录该内容2 篇文章0 订阅订阅专栏2018.11.26添加内容: 对于自己的仓库,我们建议将远程仓库通过clone命令把整个仓库克隆到本地的某一路径下。这样的话我们从本地向远程仓库提交代码时,就可以直接把需要提交的文件拖到我们之前克隆下来的
代码规范之 lint-staged 在代码提交之前,进行代码规则检查能够确保进入git库的代码都是符合代码规则的。但是整个项目上运行lint速度会很慢,lint-staged能够让lint只检测暂存区的文件,所以速度很快。 安装与配置 安装husky和lint-staged: yarn add hu
方法:1、文件没有git操作时用“git checkout--文件”命令还原;2、文件提交到暂存区时用“git reset HEAD”命令回退当前版本还原;3、文件提交到仓库区时用“git reset HEAD^”命令回退上一个版本还原。 本文操作环境:Windows10系统、Git2.30.0版、
使用Git将本地文件提交到远程仓库 一 操作准备条件: git远程仓库已经建好了,本地文件已经存在了,现在要将本地代码推到git远程仓库保存。 解决办法如下: 1、(先进入项目文件夹)通过命令 git init 把这个目录变成git可以管理的仓库 git init 2、把文件添加到版本库中,使用命令
GitHub克隆代码到本地全教程 因为工作原因更换电脑,想要从GitHub上拉取代码的话需要重新配置ssh keys,时间过的久了怕忘记就把步骤给记录下来。 具体步骤: 1.安装git 这我就不说了 2.在TortoiseGit的安装文件中找到 puttygen.exe应用程序 ,默认应该都是 :C
github上传项目的时候报出git@github.com: Permission denied (publickey). fatal: Could not read from remote repo 前言 会不会有程序员小伙伴在刚开始使用github的时候上传项目的时候困难重重,但是又基于自己本身
查看历史 git log --pretty=onelinegit log (然后一直按enter键) 一个是切换根据历史里面的id切换git checkout ID git log 需要不断按enter键出来历史提交记录 git log --pretty=oneline 是直接出来历史记录
Git工作原理及常用命令 欧怼怼发布于&#160;2020-12-08 git介绍 git(读音/ɡɪt/)是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。git是Linus Torvalds为了帮助管理Linux内核开发而开发的一个开放源码的版本控制软件。 git
git git提交项目的具体流程 git项目流程:以下主要有3个角色:负责人、成员A、成员B(若负责人也要修改代码,则负责人同时兼任2个角色:负责人、成员) 主要负责人:搭建项目架构且提交到git上1.github官网登录后,新建仓库,生成地址url,复制线上仓库.git结尾的地址url2.在一个空
git上传项目全部流程 一、下载git 进入网址:https://git-scm.com/downloads; 点击中的Download 2.16.0 for Windows; 在中选择蓝色字段点击,根据电脑64或32位选择适合的下载,点击即可进行下载,下载完成后傻瓜式安装,一直点击下一步即可完成安
Your local changes to the following files would be overwritten by checkout问题的解决 于 2018-07-17 11:38:27 发布 Git 的本地版本管理有三个部分 名称&#x9;说明工作区(Working Directory)&#x9;
Git配置SSH Keys步骤使用教程 1.若是首次安装使用git,先配置用户名称和邮箱(如果有就不需要配置) 打开Git Bash,输入 git config --global user.name &quot;姓名&quot;git config --global user.email &quot
基本配置完成,接下来就是上传你要上传的项目了。 1、初始化git 进入你要上传的项目的文件夹,在文件夹内鼠标右击,选择“Git Bash Here”打开git命令行,输入: $ git init 目的是初始化git,并且会创建个“.git”文件夹,里面有个“config”就是用来保存远程厂库路径地址
本篇内容主要讲解“gitee如何上传代码”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“gitee如何上传代码”吧! ...
这篇“从gitee上下的代码如何用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这...
这篇文章主要介绍“gitee如何下载仓库里的项目”,在日常操作中,相信很多人在gitee如何下载仓库里的项目问题上存在疑惑,小编查阅了各式资料,整理出简单好用的...
本篇内容主要讲解“怎么在Gitee上更新代码”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么在Gitee上更新代...