git初探-宏观上的git

        不知道你是不是也跟我有一样的疑虑,虽然项目里一直在用git,我们也能够使用git进行代码的管理工作,但是git究竟是什么呢?它的工作原理又是怎样的呢?---- 一头雾水。 

        最近也一直在看git的书籍,很庆幸的是不爱看书的我也有了略微小小的初悟,所以有了下面这篇文章,文章中仅代表自己对其的理解,如果有不正确的地方,欢迎大家指正。微笑

        git仓库(我更愿意将它理解为字典,当然,这是后话)

        当我们执行完 git init 或 git clone 的时候,也就在本地自动生成了一个git的相应仓库,并且会默认生成一个master分支(ps: master分支并不是特殊的存在,之所以几乎每个仓库都有,是因为在init时会默认创建)。

        ok,当我们的本地仓库创建完成后,下面我们来说说为什么说git仓库更像是一个字典吧~


        接下来,切入重点,首先让我们从宏观上看一下,由上图我们可以很容易看出,dev 是由master衍生出的分支,text分支则是在dev的f7a45版本上衍生出来的,而在这之后的所有版本都仅仅只跟当前分支有关,当然直到你将它合并到主支或它的父亲身上。如果将整个git仓库看作一个字典的话,里面的master与dev则是一级目录,而它下面所对应commit生成的快照则为它的二级,text分支则为三级。。。依次往下。构成了一个庞大的字典,而所谓的指针更像翻看字典我们的手指,当我们翻看到那一页时,当前页面的前面的所有内容是我们所知晓的,而后面的东西则需要我们再去开拓,保存在我们的记忆(git仓库)中。

        到这为止,我们讲的都只是一个俯瞰git仓库的感觉,而在我们实际开发中,这本字典可能并不是像我们想的那样 又那么多那么的章节,并且章节里还嵌套着章节。


        然后让我们先来看下git里的两个区,当我们进入分支后,也就进入到了我们的工作区,而当我们进行文件修改,执行 git add 时则是将我们修改好的文件放入到暂存区里保存,当然我们可以多次进行add操作,而当我们执行commit的时候,则是将当前已经改动的文件生成一个带有hash值的快照进行保存到仓库中,并将指针向前推进(也可以想象为我当前章节文章写完,做了个保存操作)。

        那么我们知道,很多人会认为master是一个非常特殊的分支,那么看了上图,是不是发现master也并没有什么不同??所有其他分支该有的功能,master都有,其他分支没有的,而master也没有,哈哈,好吧那略微的不同也仅仅是因为它叫master而已,那么介于它这略微的特殊,后面我们就暂且将它作为一个主分支存在吧(当然你也可以定义任意一个分支为主分支)。

        哈哈,下面让我们开启一个经典案例,帮助你更好的理解git吧~


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值