Git(5) —— Git的工作原理

it2022-12-27  86

目录

1.三个区域2.工作流程


1.三个区域

Git本地有三个工作区域:工作目录(Working Directory,平时我们存放文件的文件夹)、暂存区(Stage/Index,一个文件)、本地仓库/资源库(Repository/Git Directory/History)。如果在加上远程的git仓库(Remote Directory)就可以分为四个工作区域,文件在这四个区域之间的转换关系如下:

下图显示的提交实现流程:工作区–(git add file,提交)–>暂存区–(git commit,提交)–>本地仓库–(git push,提交)–>远程仓库;

相反就是获取实现流程:远程仓库–(git pull,拉取)–>本地仓库

Workspace:工作区,就是你平时存放项目代码的地方

Index / Stage:暂存区,用于临时存放你的改动,事实上它只是一个文件,保存即将提交到文件列表信息

Repository:仓库区(或本地仓库),就是安全存放数据的位置,这里面有你提交到所有版本的数据。其中HEAD指向最新放入仓库的版本

Remote:远程仓库,托管代码的服务器,可以简单的认为是你项目组中的一台电脑用于远程数据交换

上面的4个工作区域,一般我们直接使用的只有工作区和远程仓库,中间的两个都是使用git命令提交的时候git自己会去操作它们,我们一般不会直接操作


本地的三个区域确切的说应该是git仓库中HEAD指向的版本:

Directory:使用Git管理的一个目录,也就是一个仓库,包含我们的工作空间和Git的管理空间WorkSpace:需要通过Git进行版本控制的目录和文件,这些目录和文件组成了工作空间.git:存放Git管理信息的目录,初始化仓库的时候自动创建Index/Stage:暂存区,或者叫待提交更新区,在提交进入repo之前,我们可以把所有的更新放在暂存区Local Repo:本地仓库,一个存放在本地的版本库;HEAD会只是当前的开发分支(branch)Stash:隐藏,是一个工作状态保存栈,用于保存/恢复WorkSpace中的临时状态

2.工作流程

git的工作流程一般是这样的:

在工作目录中添加、修改文件;【对文件进行修改】将需要进行版本管理的文件放入暂存区域;【git add,将文件放入暂存区,就是一个本地的文件】将暂存区域的文件提交到git仓库【git commit,暂存区–>本地仓库–>远程仓库】

因此,git管理的文件有三种状态:已修改(modified),已暂存(staged),已提交(committed)

最新回复(0)