Git学习使用(2)

Git是开发工作中常用的版本工具,但是很多gay友都仅仅限于常规的clone、push 、pull,导致在工作中遇到误操作时不能够灵活变换,当想去学习Git的时候,往往会被一些文章中的抽象概念,工作区,暂存区,本地仓库,远程仓库绕晕,不明白仅仅是操作了本地的代码,Git如何把本地代码上传到远程服务器,哪里有这么多的动作产生。

可惜了Git这么强大的工具。本文主要想探究常用Git命令背后到底是操作了什么?常用命令的相反操作又如何执行?

本地安装完成Git之后,配置好公钥,执行以下步骤:

1、git init,初始化本地仓库,这个命令会创建一个.git子目录,所有git命令相关的操作产生的变动都在该目录下对应的文件体现,tree .git  /f  查看初始化仓库中的目录和文件。

git init

2、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 rm

3、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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容