【Git】分支

基础及常用命令部分可参考【Git】基础及常用命令

1 分支简介

1.1 分支简介

Git 保存的不是文件的变化或者差异,而是一系列不同时刻的快照。在进行提交操作时,Git 会保存一个提交对象(commit object),该提交对象会包含一个指向暂存内容快照的指针、作者的姓名和邮箱、提交时输入的信息以及指向它的父对象的指针。首次提交产生的提交对象没有父对象,普通提交操作产生的提交对象有一个父对象, 而由多个分支合并产生的提交对象有多个父对象。

创建一个工作目录git_demo_02,执行git init命令后,新建三个文件 LICENSEREADMEtest.rb

$ git init
Initialized empty Git repository in D:/git_space/git_demo_02/.git/

$ ls -a
./  ../  .git/  LICENSE  README  test.rb

$ cat LICENSE
this is LISENCE first line

$ cat README
this is README first line

$ cat test.rb
this is test.rb first line

暂存操作会为每一个文件计算校验和(使用SHA-1哈希算法),然后会把当前版本的文件快照保存到 Git 仓库中(Git 使用 blob 对象来保存它们),最终将校验和加入到暂存区域等待提交:

$ git add README test.rb LICENSE
$ git commit -m 'The initial commit of git_demo_02'

当使用git commit进行提交操作时,Git 会先计算每一个子目录(本例中只有项目根目录)的校验和, 然后在 Git 仓库中将这些校验和保存为树对象。随后,Git 便会创建一个提交对象, 它除了包含上面提到的那些信息外,还包含指向这个树对象(项目根目录)的指针。 如此一来,Git 就可以在需要的时候重现此次保存的快照。
现在,Git 仓库中有五个对象:三个 blob 对象(保存着文件快照)、一个 树 对象 (记录着目录结构和 blob 对象索引)以及一个 提交 对象(包含着指向前述树对象的指针和所有提交信息)。
首次提交对象及其树结构
做些修改(在README文件末尾添加一行)后,再次提交,这次产生的提交对象会包含一个指向上次提交对象(父对象)的指针。
提交对象及其父对象
Git 的分支,本质上是指向提交对象的可变指针。Git 的默认分支是master,master 分支会在每次提交时自动向前移动, 在多次提交操作之后,master 分支指向最后那个提交对象。
分支及其提交历史

1.2 分支创建

创建新分支时,Git 只是创建了一个可以移动的新的指针。 使用git branch命令创建一个 testing 分支:

$ git branch testing

这会在当前所在的提交对象上创建一个指针。
Git有一个名为HEAD的特殊指针,指向当前所在的本地分支。git branch命令仅仅创建一个新分支,并不会自动切换到新分支中去,所以现在仍然在 master 分支上。
HEAD 指向当前所在的分支
可以使用git log --decorate命令查看各个分支当前所指的对象,发现当前 master 和 testing 分支指向同一个提交对象:

$ git log --oneline --decorate
c1b8cde (HEAD -> master, testing) The second commit of git_demo_02
b16ac6e The initial commit of git_demo_02

1.3 分支切换

可以使用git checkout命令切换到一个已存在的分支。现在切换到新创建的 testing 分支:

$ git checkout testing
Switched to branch 'testing'

这样 HEAD 就指向 testing 分支了。
HEAD 指向当前所在的分支
做些修改(在README文件末尾添加一行)后,再次提交后,testing 分支向前移动,但 master 分支仍指向运行 git checkout 时所指的对象。

$ git log --oneline --decorate
fdf1751 (HEAD -> testing) The third commit of git_demo_02
c1b8cde (master) The second commit of git_demo_02
b16ac6e The initial commit of git_demo_02

HEAD 分支随着提交操作自动向前移动
现在,切换回 master 分支。切换的过程做了两件事:一是使 HEAD 指回 master 分支;二是将工作目录恢复成 master 分支所指向的快照内容。本质上来讲,这就是在master分支上忽略 testing 分支所做的修改。

$ git checkout master
Switched to branch 'master'

$ git log --oneline --decorate
c1b8cde (HEAD -
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值