工做原理 / 流程:git
1:git init初始化算法
主要目录说明缓存
objects-存储对象的目录,本地仓库,git中对象分为三种:commit对象,tree对象(多叉树),blob对象;文件都是blob对象,二进制存储;spa
Refs-存储指向branch的最近一次commit对象的指针,也就是commit对象的sha-1值(就是hash值,sha-1是一种散列算法);.net
HEAD文件-该文件表示当前本地签出的分支;3d
Index文件-存储缓冲区(GitExtensions中的stage)的内容,内容包括它指向的文件的时间戳、文件名、sha1值等;(git三大区域:工做区,缓冲区,历史记录区)指针
2:git add * 指定文件写入缓存区,生成Git对象日志
在objects目录建立目录和文件对象
git是一套内容寻址系统,它是怎样寻址的呢?blog
Git从核心上来看不过是简单地存储键值对(key-value)(hashmap),大概结构以下:
Key=sha-1(file header + file content)
Value=压缩(file content)
Key是一个40位字符的校验和,前2位做为子目录,后38位做为文件名保存在子目录下。
3:git cat-file -t 58c9 查看object的类型
其中58是目录,C9是文件名前两位(58c9也可替换为key(目录+文件名)), 此时返回blob
4:git cat-file -p 58c9 查看文件内容
返回文件内容信息,不包括文件名等其余信息
5:git commit -m用于提交暂存区的文件;git commit -am用于提交跟踪过的文件
git commit -am提交已跟踪过本地修改未执行add进入缓存区的文件=git add +git commit -m合并执行
其中已跟踪并修改的文件产生新的object
提交后Git仓库里面object的类型发生变化,增长了其它目录(tree commit两种类型)可用第3点执行新的目录和文件,一个是commit,一个是tree
git cat-file -p 4caa查看tree类型的文件信息,从它储存的内容来看能够发现它储存了一个目录结构(相似于文件夹),以及每个文件(或者子文件夹)的权限、类型、对应的身份证(SHA1值)、以及文件名。
此时的Git仓库关系是tree-blob结构
commit类型信息,它储存的是一个提交的信息,包括对应目录结构的快照tree的哈希值,上一个提交的哈希值
能够理解为commit是一次提交的根节点
git add 在暂存区索引Index创建与blob object的连接关系
git commit 根据索引区的连接信息建立commit-tree-blob的新连接关系,
同时将版本指针指向新的连接关系,在commit记录上一版本的key
6:分支信息储存-.git/refs/heads/master文件存储最新commit的key地址
7:Git的三个分区(工做目录、Index 索引区域、Git仓库)
工做区:就是你在电脑里能看到的目录。
版本库:工做区有一个隐藏目录.git,这个不算工做区,而是Git的版本库,由Git object记录着每一次提交的快照,以及链式结构记录的提交变动历史。
暂存区:通常存放在 “.git目录下” 下的index文件(.git/index)中,因此咱们把暂存区有时也叫做索引(index)这里面的代码会在下一次commit被提交到Git仓库。。
经常使用命令:
git log命令显示从最近到最远的显示日志
git reset --hard HEAD^ 回退到上一个版本,若是要回退到上上个版本只需把HEAD^ 改为 HEAD^^ 以此类推。那若是要回退到前100个版本的话,使用上面的方法确定不方便,咱们可使用下面的简便命令操做:git reset --hard HEAD~100 便可
git reflog 查看提交记录版本号
git reset --hard 版本号退到指定版本
git checkout -- 文件名 把在工做区中的文件作的修改所有撤销(若是已commit则退回最后一个版本,若是add则从缓存区获取)
查看分支:git branch
建立分支:git branch name
切换分支:git checkout name
建立+切换分支:git checkout –b name
合并某分支到当前分支:git merge name
删除分支:git branch –d name
参考资料
https://mp.weixin.qq.com/s/UQKrAR3zsdTRz8nFiLk2uQ
https://blog.csdn.net/Miracle_Yan/article/details/80224839