2.4.1.1. 分支

分支是 Git 最重要的概念之一,也是最常用的操作之一。几乎所有 Git 操作流程都离不开分支。

git branch命令可以列出本地的所有分支。

$ git branch

创建一个名为MyBranch的新分支,但是依然停留在当前分支。

$ git branch MyBranch

在远程主机origin上创建一个MyBranch的分支,并与本地的同名分支建立追踪关系。

$ git push -u origin MyBranch

将当前分支改名为MyBranch

$ git branch -m MyBranch

删除MyBranch分支,前提是该分支没有未合并的变动。

$ git branch -d MyBranch

强制删除MyBranch分支,不管有没有未合并变化。

$ git branch -D MyBranch

切换到MyBranch分支,当前的工作区会变为MyBranch分支的内容。

$ git checkout MyBranch

基于MyBranch分支创建一个新的NewBranch分支,新的NewBranch分支将成为当前的工作区。

$ git checkout -b NewBranch MyBranch

2.4.1.2. 内部实现

2.4.1.2.1. .git 目录

版本管理的所有信息,保存在项目的.git目录之中。如果没有这个目录,Git 就会认为这个仓库没有建立版本管理,必须进行初始化。git init命令的主要作用,就是建立.git目录。

.git/config文件保存仓库的设置。

.git/HEAD文件保存当前工作分支的引用。

.git/hooks目录保存各种事件挂钩的脚本。

.git/objects目录保存文件的内容,格式是二进制blob

2.4.1.2.2. 哈希签名

每次提交的时候,每个文件、每个树节点(目录)和提交本身,都会生成一个40个字符长的 SHA-1 哈希。

哈希作为文件名,文件本身保留在.git/objects目录之中。

2.4.1.2.3. git add 命令

git add会将变动的文件写入.git/objects目录。它内部调用的是git hash-object命令,该命令会计算 SHA-1 哈希,并将 blob 文件放入.git/objects目录。

$ git hash-object -w myfile.txt

git cat-file命令可以查看 blob 格式对应的原始文件内容。

$ git cat-file -p e69de29bb2d1d6434b8b29ae775ad8c2e48c5391

2.4.1.2.4. git commit 命令

git commit命令用于有变动的、并已提交到.git/objects的文件写入历史。

git write-tree为当前仓库创建树节点。

$ git write-tree

git commit-tree命令将指定的树节点写入历史。

$ echo“first commit”| git commit-tree \ 6e9432aeedbad83fbffb7f8aae4a5d1ab50b7fdf

2.4.1.3. 标签

2.4.1.3.1. 推送

标签必须单独推送。也就是说,git push命令默认不会推送标签,必须使用--tags参数。

$ git push && git push --tags

上面的命令先推送新的 commit,成功后再单独推送标签。

--follow-tags参数会使得 commit 以及与之相关的标签(注意,不是所有的标签)一起推送。

$ git push --follow-tags

Git 有一个对应于--follow-tags的配置项,默认是关闭的。如果将它打开,以后执行git push的时候,默认就会带上--follow-tags

$ git config --global push.followTags true

results matching ""

    No results matching ""