【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)。

相关推荐
Yupureki8 小时前
《Linux网络编程》8.网络层IP原理
linux·运维·服务器·网络·ip
Je1lyfish9 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
程序员飞哥9 小时前
重构 AI 思维(一):Prompt Engineering,如何下达不可违抗的指令?
人工智能·后端
皮皮林55110 小时前
@Autowired 和 @Resource 注解有啥区别?你这项目怎么还混着用呢?
后端
程序员小假11 小时前
HTTP3 性能更好,为什么内网微服务依然多用 HTTP2?HTTP2 内网优势是什么?
java·后端
___波子 Pro Max.11 小时前
Git Remote 仓库地址变更
git
wangbing112511 小时前
踩坑:el8应用装在el9上
开发语言·后端·ruby
xyy_49611 小时前
wsl-localhost
linux
kyriewen1112 小时前
你等的Babel编译,够喝三杯咖啡了——用Rust重写的SWC,只需眨个眼
开发语言·前端·javascript·后端·性能优化·rust·前端框架
IT_陈寒12 小时前
SpringBoot自动配置坑了我,原来要这样绕过去
前端·人工智能·后端