Git是开发工作中常用的版本工具,但是很多gay友都仅仅限于常规的clone、push 、pull,导致在工作中遇到误操作时不能够灵活变换,当想去学习Git的时候,往往会被一些文章中的抽象概念,工作区,暂存区,本地仓库,远程仓库绕晕,不明白仅仅是操作了本地的代码,Git如何把本地代码上传到远程服务器,哪里有这么多的动作产生。
可惜了Git这么强大的工具。本文主要想探究常用Git命令背后到底是操作了什么?常用命令的相反操作又如何执行?
本地安装完成Git之后,配置好公钥,执行以下步骤:
1、git init,初始化本地仓库,这个命令会创建一个.git子目录,所有git命令相关的操作产生的变动都在该目录下对应的文件体现,tree .git /f 查看初始化仓库中的目录和文件。
git init2、git add,在工作区新增一个文件testFile.txt,执行命令git add .当执行这个命令的时候,观察.git中目录和文件的变化。
git add通过命令查看objects的文件
查看objects存储类型——git cat-file -t bdf08d
查看objects存储内容——git cat-file -p bdf08d
查看文件类型,和文件内容上述命令查看,发现git add命令会生成objects,存储类型blob,存储了文件的内容,注意objects不存储文件的名字。
Git通过固定算法,将文件内容生成固定长度的hash值。而文件名的信息就存储在了新增的index(索引区)文件中,通过命令git ls-files -s查看,存在文件名和文件内容hash值的对应关系。
查看索引区这里同样能够理解了为什么git status命令查看时,Git可以追踪到工作区文件的状态,本质是Git校验了工作区文件和索引区文件的内容hash和是否存在文件名和hash的对应关系。
git add命令实现文件从工作区——>索引区的变化,以下两种文件状态变更时使用:
Untracked——>Staged,使用git add
Modified——>Staged,使用git add
git add对应的反向操作,将指定文件移除索引区,执行命令git rm --cached spring.log
git rm3、git commit,执行commit命令,并观察.git中目录和文件的变化。
git commit.git目录文件变化
新生成两个objects对象,通过命令查看objects的文件:
查看objects存储类型——git cat-file -t 792e4b4,git cat-file -t 514cc27
查看objects存储内容——git cat-file -p 792e4b4 ,git cat-file -p514cc27
792e4b4为commit对象:包含一个tree对象、author信息及commit的信息,以及parent指向上一次commit记录
514cc27为tree对象:包含文件内容的hash和文件名对应关系。
除此之外commit命令产生的变化还有当前指针的变化,HEAD文件永远指向当前的工作分支,通过命令可以看出当前的工作分支master指向最新的commit对象。
HEAD指向当前工作分支git commit命令实现文件从索引区——>本地仓库的变化:
Staged——>Unmodified,使用git commit
git commit反向操作,执行git reset HEAD^:
意味着返回上一个版本,撤销commit,
不撤销git add
工作空间改动的代码保留。
git reset HEAD^文章参考B站学习视频:https://space.bilibili.com/364122352?from=search&seid=18202198804764648480
参考书籍《pro Git》 Scott Chacon, Ben Straub
网友评论