git的本质是资源库和版本(资源)目录的维护过程

仓库的本质:

资源+索引。

对git而言,添加到暂存区的过程是,将单个资源的修改副本保存到资源库,同时维护暂存区目录的过程。

 

git的本质是资源库和版本目录的维护过程。

 

一、要素

1、资源

2、副本

3、版本库

4、暂存区

5、修改(变动)

 

二、操作

1、clone:创建副本(包含版本库)

2、add:将修改放置到缓存区;

3、commit:将缓存区同步到版本库;

4、拉取、抓取:将远程库的代码同步到本地;

5、push:将本地的修改同步到远程库。

6、分支与合并:创建新的版本库。

 

三、

基本概念

我们先来理解下Git 工作区、暂存区和版本库概念

  • 工作区:就是你在电脑里能看到的目录。
  • 暂存区:英文叫stage, 或index。一般存放在"git目录"下的index文件(.git/index)中,所以我们把暂存区有时也叫作索引(index)。
  • 版本库:工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。

下面这个图展示了工作区、版本库中的暂存区和版本库之间的关系:

201609291519223166.png

图中左侧为工作区,右侧为版本库。在版本库中标记为 "index" 的区域是暂存区(stage, index),标记为 "master" 的是 master 分支所代表的目录树。

图中我们可以看出此时 "HEAD" 实际是指向 master 分支的一个"游标"。所以图示的命令中出现 HEAD 的地方可以用 master 来替换。

图中的 objects 标识的区域为 Git 的对象库,实际位于 ".git/objects" 目录下,里面包含了创建的各种对象及内容。

当对工作区修改(或新增)的文件执行 "git add" 命令时,暂存区的目录树被更新,同时工作区修改(或新增)的文件内容被写入到对象库中的一个新的对象中,而该对象的ID被记录在暂存区的文件索引中。

当执行提交操作(git commit)时,暂存区的目录树写到版本库(对象库)中,master 分支会做相应的更新。即 master 指向的目录树就是提交时暂存区的目录树。

当执行 "git reset HEAD" 命令时,暂存区的目录树会被重写,被 master 分支指向的目录树所替换,但是工作区不受影响。

https://www.w3cschool.cn/git/git-workspace-index-repo.html

 

 

四、

前者是 ,后者是 , 等于 。

前面两个楼上已经说的很好了,我再用大白话说一下,拉取会把你本地仓库没有 而远程仓库有的更新写到你本地中,而获取的用处更多的是用来查看对于你本地仓库的状态来说远程仓库是否有更新,仅此而已,并不会使你的本地仓库发生改变

 

 

参考文献:

resourcetree中的拉取和获取有什么区别

https://segmentfault.com/q/1010000007703027

posted @ 2019-11-07 11:28  zzfx  阅读(421)  评论(0编辑  收藏  举报