【Git】详解本地仓库的创建、配置以及工作区、暂存区、版本库的认识

一、创建本地仓库

需要将本地仓库放在一个目录下,所以在创建本地仓库之前,应该先创建一个目录,再进入这个目录:

在这个目录中创建一个本地仓库:

复制代码
git init

创建完成后,我们就会发现当前目录下多了一个.git的隐藏文件:

这样就表示本地仓库已经创建完成了。

二、本地仓库的配置

本地仓库创建以后要为其设置用户名和邮箱:

bash 复制代码
git config user.name "用户名"
git config user.email "邮箱"

如果加上--global选项表示设置的用户名或邮箱会在所有的本地仓库中生效:

bash 复制代码
git config --global user.name "用户名"
git config --global user.email "邮箱"

如果要取消设置的用户名或邮箱,直接加上--unset选项即可:

bash 复制代码
git config --unset user.name "用户名"
git config --unset user.email "邮箱"
git config --global --unset user.name "用户名"
git config --global --unset user.email "邮箱"

git config -l:可以用来查看当前git的配置列表。

三、工作区、暂存区、版本库的认识

我们不能直接修改.git目录下的内容。.git就叫做本地仓库,也叫做版本库,我们要修改只能在创建了本地仓库的这个目录中增删文件,我们把这个目录叫做本地仓库的工作区。

在上图中, stage叫做暂存区或者是索引**。我们日常所做的add操作就会将工作区中修改(新增,修改,删除)的内容保存到暂存区中,我们日常所做的commit操作就是将暂存区中的内容添加到master分支中,经过第二步commit操作我们才能说我们已经将工作区中修改的内容放在了版本库中,经过add和commit两步后我们才能让git来管理修改的内容。**

在版本库中,其实还有一个叫对象库的东西,修改的工作区的内容会写入对象库的一个新的git对象中,每add一次对象库就会存放一次修改的内容的对象, 保存了每一次修改的内容其实就做到了版本的管理**。暂存区中其实保存的就不是一个个的对象了而是对象的索引,所以暂存区是比较轻量级的,从而我们也可以知道,master分支中其实存放的也是对象的索引。**

从上面的.git的树状图中我们也可以看到,有HEAD指针,对象库(objects)。

相关推荐
RoyLin4 分钟前
TypeScript设计模式:策略模式
前端·后端·typescript
brzhang14 分钟前
为什么说低代码谎言的破灭,是AI原生开发的起点?
前端·后端·架构
得物技术1 小时前
破解gh-ost变更导致MySQL表膨胀之谜|得物技术
数据库·后端·mysql
小码编匠1 小时前
WPF 中的高级交互通过右键拖动实现图像灵活缩放
后端·c#·.net
Java水解1 小时前
【MySQL】从零开始学习MySQL:基础与安装指南
后端·mysql
Java水解1 小时前
Scala深入面向对象:类、对象与伴生关系
后端·scala
LeeGe1 小时前
基于binlog的canal到redis的同步
后端
kfyty7251 小时前
loveqq-bootstrap 和 springcloud-bootstrap 有什么区别
后端·架构
RoyLin1 小时前
TypeScript设计模式:桥接模式
前端·后端·typescript
CryptoRzz2 小时前
印度尼西亚股票数据API对接实现
javascript·后端