git 分支原理介绍

栏目: 编程工具 · 发布时间: 7年前

内容简介:自然的,首次提交的对象是没有父指针的,之后提交的对象才有父指针。

参考文章

工作原理

git 的工作原理:

git 版本控制是通过保存不同时间点的快照实现的。 git 在提交操作时, git 会保存一个提交对象,该提交对象中会包含:用户名,邮箱,提交信息,以及指向它父对象的指针。

自然的,首次提交的对象是没有父指针的,之后提交的对象才有父指针。

  • 用户名
  • 邮箱
  • 提交信息
  • 父指针
  • 指向树对象的指针(树对象: git 通过计算每个子目录的校验和,将其保存为树对象)

    blob
    

git 的分支,其实本质上是指向提交对象的可变指针。由于创建分支的高效性,所以, git 鼓励开发人员创建分支!

原理说明

首先在创建 git 项目的时候,默认会创建 master 分支!这个 master 分支正常应该是指向最新一次提交。

head
              |
              master
              |
one <- two <- thr

假设这个时候,用户做了些修改,然后提交:

head
                     |
                     master
                     |
one <- two <- thr <- four

从上述两个过程可以看出, master 分支实际就是一个指向某次提交的指针!会根据用户的提交自动向前移动指向最新一次提交。

如果用户新创建了一个分支( test )呢:

git branch test

他的实际结果就是如下:

head
                     |
                     master
                     |
one <- two <- thr <- four
                     |
                     test

因为这个时候用户在 master 分支下,用户再次做出修改提交:

test
                     |
one <- two <- thr <- four <- five
                             |
                             master
                             |
                             head

如果这个时候用户切换到 test 分支( git checkout test ),做些修改然后再次提交:

head
                              |
                              test
                              |
                           <- five-for-test
one <- two <- thr <- four 
                           <- five
                              |
                              master

产生了一个新的分支!!


以上所述就是小编给大家介绍的《git 分支原理介绍》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

算法图解

算法图解

[美] Aditya Bhargava / 袁国忠 / 人民邮电出版社 / 2017-3 / 49.00元

本书示例丰富,图文并茂,以让人容易理解的方式阐释了算法,旨在帮助程序员在日常项目中更好地发挥算法的能量。书中的前三章将帮助你打下基础,带你学习二分查找、大O表示法、两种基本的数据结构以及递归等。余下的篇幅将主要介绍应用广泛的算法,具体内容包括:面对具体问题时的解决技巧,比如,何时采用贪婪算法或动态规划;散列表的应用;图算法;K最近邻算法。一起来看看 《算法图解》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具