内容
- 基本原理
- git 常用命令
- 较底层的原理
基本原理
Git 实际上是一个内容寻址系统。
Git 中保存的所有数据,包括:文件内容、提交信息、项目快照等数据都会被转换为二进制文件并压缩后存放在 .git
中的 objects
文件夹中。
Git 在转换并压缩这些数据的同时,会以特定的算法(SHA-1)生成每个数据对应的由40个的十六进制字符(0-9 和 a-f)组成的字符串,一般可以称之为hash(哈希)。
这个hash的特点是:
- 该hash根据文件的类型和内容生成
- hash值相同,则文件内容相同
Git 仓库中的文件类型有四种:blob
、commit
、tree
、tag
,先不讲 tag
类型。
blob
类型文件用来存放项目文件的内容,但是不包括文件的路径、名字、格式等其它描述信息。项目的任意文件的任意版本都是以blob的形式存放的。比如 Git 仓库中有一个 README.MD
文件,里面有一句文字为"hello world",则在 .objects
文件夹中一定会有一个类型为 blob
的文件,其中的二进制数据经过转换后的值为"hello world"。
commit
类型文件存放项目的提交对象信息。其中的 parent
字段指向其父提交,tree
字段指向项目的快照,还有一些提交信息,比如作者姓名啥的。
tree
类型文件存放了整个项目的结构,用来表示项目的目录情况。因为项目其实就是一个目录,目录中有文件、有子目录。因此 tree
中有 blob
、子tree
,且都是使用 sha-1值引用的。这是与目录对应的。从顶层的 tree
纵览整个树状的结构,叶子结点就是 blob
,表示文件的内容,非叶子结点表示项目的目录,顶层的 tree
对象就代表了当前项目的快照。
Git 将生成的hash作为所有数据的索引。包括提交对象、文件内容、项目快照全部通过hash索引位置。
因此我们很容易联想到,其实分支就是指向某个提交对象的hash值,只是我们给予了其一个别名。
两个状态和三个状态
两个状态
已追踪
,未追踪
三个状态
处于 已追踪
状态下的文件会被纳入 Git 仓库进行管理,这时其拥有了已修改
,已暂存
,已提交
三个状态。
根据上面的三个状态,我们有了三个工作区域的概念:工作目录、暂存区域、以及Git 仓库。
基本的 Git 工作流程如下:
- 在工作目录中修改文件。
- 暂存文件,将文件的快照放入暂存区域。
- 提交更新,找到暂存区域的文件,将快照永久性存储到 Git 仓库目录。
基于上面的概念,Git 文件的状态变化周期如下图:
git 常用命令
git clone [url] - 克隆项目
git add [file name] - 提交指定文件或标记文件已合并成功或追踪指定文件
git add . - 提交处于已修改状态的所有文件或标记合并成功或追踪所有未被追踪的文件(文件不在.gitignore中)
git commit - 打开编辑器进行提交操作
git commit -a - 跳过暂存直接将已修改的文件提交
git commit -m [commit info] 当行提交命令进行提交
git commit --amend - 撤销最后一次提交
git reset --hard [commit hash] - 以最后一次提交的数据为基础,撤销暂存区,工作目录中的所有更新
git reset [file name] - 将指定文件从暂存区撤销
git push - 将提交推送到与本地分支建立了追踪关系的远程分支
git pull - 拉取与本地分支建立了追踪关系的远程分支上的最新提交并与本地分支进行合并
git fetch - 同 git pull ,但是不会主动合并
git diff - 查看工作目录中文件的变化
git diff --cached \ git diff --staged - 查看已经暂存的文件相对于最后一次提交的变化
git branch -vv - 显示本地分支和远程分支的追踪关系
git branch -d [branch] - 删除本地分支
git branch --merged - 显示已与当前分支进行了合并的分支
git branch --no-merged - 显示还未与当前分支合并的分支
git merge [branch] - 将指定的分支合并到当前分支
git rebase [base branch] [topic branch] - 将指定分支[topic branch]变基到当前分支[base branch]
git stash - 将当前还未提交的更新储藏到栈中
git stash apply [stash name] - 应用指定的储藏到当前项目中
git stash drop [stash name] - 删除指定储藏
git stash pop - 将最后储藏的更新信息应用到当前工作目录中并删除该储藏
git log - 查看提交记录
git log -p - 查看提交记录的详细信息,类似于 git diff
git log --stat - 查看提交较详细的信息