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

相关推荐
恋喵大鲤鱼13 分钟前
git merge
git·git merge
weixin_5231853226 分钟前
Collections.unmodifiableMap详解:真的不可修改吗?
java·linux·前端
swipe36 分钟前
做多轮对话 Agent,为什么我建议把短期记忆放到 Redis
后端·面试·llm
码客日记1 小时前
Spring Boot 配置文件敏感信息加密(Jasypt 企业级完整方案)
java·spring boot·git
程序员黑豆1 小时前
AI全栈开发之Java:什么是JDK
前端·后端·ai编程
_codemonster1 小时前
Codex 核心进阶玩法(技能/MCP/派生/分叉/Git/钩子/子智能体)
git
逻极1 小时前
Git 从入门到精通:版本控制协作实战指南
git·github·分支管理·版本控制
恋喵大鲤鱼1 小时前
git clean
git·git clean
凡人叶枫1 小时前
Effective C++ 条款04:确定对象被使用前已先被初始化
java·linux·开发语言·c++·嵌入式开发
阿明在折腾1 小时前
从Canvas到AI模型:我在线工具站里的图片处理实战
前端·后端