深入理解Git (三) - 微命令上篇
1 git hash-object
曾经讲过Git用Hash值作为Git对象的名字,那么详细是哪个命令呢?
我们能够先改动一个文件:
echo "hongchangfirst" > zhc.conf
然后
git hash-object -w zhc.conf
56166dc42a6a2f694e088694a2a2c90606e28f2d
然后我们能够去上节讲的.git/objects文件夹下,应该有一个名字为56的文件夹。里边会有一个名字为166dc42a6a2f694e088694a2a2c90606e28f2d的文件,我们开打这个文件看看里边是什么东西:
一堆乱码。为什么呢,由于Git用zlib进行了压缩,那么怎么看呢?继续往下看。
2 git cat-file
我们首先看一下56166dc42a6a2f694e088694a2a2c90606e28f2d这个对象是什么?
git cat-file -t 56166dc42a6a2f694e088694a2a2c90606e28f2d
blob
哦,原来是blob对象,上节讲过blob是数据对象,那么我们看看里边的内容呢?
git cat-file -p 56166dc42a6a2f694e088694a2a2c90606e28f2d
hongchangfirst
哦。原来能够这么看。可是zhc.conf在哪存储呢?继续往下看。
3 git update-index
zhc.conf这样的文件名称信息是存储在tree对象里的,而生成tree对象。必须先将blob对象加入到cache中,当中存储item数据块集合。而item数据块是由blob对象Hash值+数据文件名称字(zhc.conf)+文件模式(100644)组成的。
git update-index --add --cacheinfo 100644 56166dc42a6a2f694e088694a2a2c90606e28f2d zhc.conf
假设有多个文件,能够继续将文件对blob对象,文件名称和文件模式写到cache里。
4 git ls-files
查看一下cache种都有哪些文件,
git ls-files
zhc.conf
当全部当数据我们都加入到cache中后,我们就能够生成tree对象了。
5 git write-tree
4e1ba2916b4b903d2e5a2209cdcca7129a891c2f
此时我们能够进入.git/objects/4e/ 查看此tree对象。
git cat-file -t 4e1ba2916b4b903d2e5a2209cdcca7129a891c2f
tree
告诉我们是tree对象,看看里边的内容:
git cat-file -p 4e1ba2916b4b903d2e5a2209cdcca7129a891c2f
100644 blob 56166dc42a6a2f694e088694a2a2c90606e28f2d zhc.conf
我们看到能够依据tree对象找到对应的blob对象。
原文:http://blog.csdn.net/hongchangfirst/article/details/45333575
作者:hongchangfirst
hongchangfirst的主页:http://blog.csdn.net/hongchangfirst
深入理解Git (三) - 微命令上篇的更多相关文章
- 使用git微命令深入理解git工作机制
首先.这篇不是真正意义上的翻译,所以大家在看的时候不要找相应的英文文章相应着看.这篇文章之所以归类为翻译.是由于最開始有一篇英文文章让我对git内部机制有了清楚的认识,它能够说是我git的启蒙老师吧. ...
- 深入理解git,从研究git目录开始
转发学习的啦. 似乎很少有人在读某个git快速教程的时候会说:“这个关于git的快速教程太酷了!读完了用起git来超级舒服,并且我一点也不怕自己会破坏什么东西.” 对git的初学者来说,刚接触git时 ...
- 理解Git的工作流程(转)
英文原文:Understanding the Git Workflow 如果你不理解Git的设计动机,那你就会处处碰壁.知道足够多的命令和参数后,你就会强行让Git按你想的来工作,而不是按Git自己的 ...
- 理解git经常使用命令原理
git不同于类似SVN这样的版本号管理系统,尽管熟悉经常使用的操作就能够满足大部分需求,但为了在遇到麻烦时不至于靠蛮力去尝试,了解git的原理还是非常有必要. 文件 通过git管理的文件版本号信息所有 ...
- 理解git的分支原理,更好地使用git
文章内容转载于git-scm. 部分内容涉嫌枯燥 一.git分支概念 几乎每一种版本控制系统都以某种形式支持分支.使用分支意味着你可以从开发主线上分离开来,然后在不影响主线的同时继续工作.在很多版本控 ...
- 深入理解Git - 一切皆commit
在对 git 有了基本理解和知道常规操作之后,如何对 git 的使用有进一步的理解? 一切皆 commit 或许是个不错的理解思路. 本文将从『一切皆 commit 』的角度,通过 git 中常见的名 ...
- [转发]深入理解git,从研究git目录开始
转发学习的啦. 似乎很少有人在读某个git快速教程的时候会说:“这个关于git的快速教程太酷了!读完了用起git来超级舒服,并且我一点也不怕自己会破坏什么东西.” 对git的初学者来说,刚接触git时 ...
- 全面理解Git
前言 人生贵知心,定交无暮早. 原文博客地址:Git命令总结 知乎专栏&&简书专题:前端进击者(知乎) 前端进击者(简书) 正文 1.Git简介 Git的诞生确实是一个有趣的故事,我 ...
- 深入理解OOP(三):多态和继承(动态绑定和运行时多态)
在前面的文章中,我们介绍了编译期多态.params关键字.实例化.base关键字等.本节我们来关注另外一种多态:运行时多态, 运行时多态也叫迟绑定. 深入理解OOP(一):多态和继承(初期绑定和编译时 ...
随机推荐
- [BZOJ4247]挂饰(DP)
当最终挂饰集合确定了,一定是先挂挂钩多的在挂挂钩少的. 于是按挂钩从大到小排序,然后就是简单的01背包. #include<cstdio> #include<algorithm> ...
- Dalvik和ART的区别
什么是Dalvik: Dalvik是Google公司自己设计用于Android平台的Java虚拟机.Dalvik虚拟机是Google等厂商合作开发的Android移动设备平台的核心组成部分之一. ...
- 最短路:我的理解--Dijkstra算法
最短路径:Dijkstra算法 用来计算从一个点到其他所有点的最短路径的算法,是一种单源最短路径算法.也就是说,只能计算起点只有一个的情况. Dijkstra的时间复杂度是O (N2),它不能处理存在 ...
- MySQL主库切换那些事
最近连续经历了机架掉电和交换机挂掉,着实切了不少主库,虽然过程心惊胆跳,但是也算是上过战场,经过了实战演习,相信TEAM中的小伙伴们对于切主库已经可以驾轻就熟了. MySQL的主库切换也属于DBA的一 ...
- 二叉树遍历-JAVA实现
二叉树遍历分为前序.中序.后序递归和非递归遍历.还有层序遍历. //二叉树节点 public class BinaryTreeNode { private int data; private Bina ...
- [HTML]不让TD中的文本撑开表格(转)
我经常会遇到这样的问题:在设计好宽度的表格中,因为有些文本信息过长,而把表格撑开(弄的面目全非)!很让人头疼.其实解决这个问题很简单,只要在<td>的样式中加入word-break: br ...
- Linux下查找命令(收集整理)
原文:http://blog.csdn.net/sunstars2009918/article/details/8510878 一.Linux查找文件的相关命令 常 用 命 令 简要中文说明 程序所在 ...
- Go:《Go语言 云动力》
背景 中秋快速的读了一遍<Go语言 云动力>,对Go有一下几点感觉: 在静态类型和动态类型之间取得了非常好的平衡,隐式接口实现会被后续的语言借鉴(希望C#能借鉴一下). 缺乏异常处理机制, ...
- 固定的价格就意味着背叛——《practices of an agile developper》
“对这个项目,我们必须要有固定的报价.虽然我们还不清楚项目的具体情况,但仍要有一个报价.到星期一,我需要整个团队的评估,并且我们必须要在年末交付整个项目.” Venkat & Andy 提出了 ...
- 常用EDA工具环境变量配置
# EDA Toolsexport SYNOPSYS_HOME=/home/ProgramFiles/synopsysexport VCS_ARCH_OVERRIDE=linuxexport VCS_ ...