Git 教程之工作区、暂存区和版本库详解
作者:菜鸟教程 时间:2022-11-28 04:07:40
Git 工作区、暂存区和版本库
基本概念
我们先来理解下Git 工作区、暂存区和版本库概念
工作区:就是你在电脑里能看到的目录。
暂存区:英文叫stage, 或index。一般存放在"git目录"下的index文件(.git/index)中,所以我们把暂存区有时也叫作索引(index)。
版本库:工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。
下面这个图展示了工作区、版本库中的暂存区和版本库之间的关系:
图中左侧为工作区,右侧为版本库。在版本库中标记为 "index" 的区域是暂存区(stage, index),标记为 "master" 的是 master 分支所代表的目录树。
图中我们可以看出此时 "HEAD" 实际是指向 master 分支的一个"游标"。所以图示的命令中出现 HEAD 的地方可以用 master 来替换。
图中的 objects 标识的区域为 Git 的对象库,实际位于 ".git/objects" 目录下,里面包含了创建的各种对象及内容。
当对工作区修改(或新增)的文件执行 "git add" 命令时,暂存区的目录树被更新,同时工作区修改(或新增)的文件内容被写入到对象库中的一个新的对象中,而该对象的ID被记录在暂存区的文件索引中。
当执行提交操作(git commit)时,暂存区的目录树写到版本库(对象库)中,master 分支会做相应的更新。即 master 指向的目录树就是提交时暂存区的目录树。
当执行 "git reset HEAD" 命令时,暂存区的目录树会被重写,被 master 分支指向的目录树所替换,但是工作区不受影响。
当执行 "git rm --cached <file>" 命令时,会直接从暂存区删除文件,工作区则不做出改变。
当执行 "git checkout ." 或者 "git checkout -- <file>" 命令时,会用暂存区全部或指定的文件替换工作区的文件。这个操作很危险,会清除工作区中未添加到暂存区的改动。
当执行 "git checkout HEAD ." 或者 "git checkout HEAD <file>" 命令时,会用 HEAD 指向的 master 分支中的全部或者部分文件替换暂存区和以及工作区中的文件。这个命令也是极具危险性的,因为不但会清除工作区中未提交的改动,也会清除暂存区中未提交的改动。
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
C#定制Excel界面并实现与数据库交互的方法
![](https://img.aspxhome.com/file/2023/9/81119_0s.jpg)
Python 函数返回值的示例代码
JS 实现10进制转换36进制的示例代码
![](https://img.aspxhome.com/file/2023/7/132737_0s.png)
django-allauth入门学习和使用详解
对TensorFlow的assign赋值用法详解
vuex中数据持久化插件vuex-persistedstate使用详解
![](https://img.aspxhome.com/file/2023/2/133122_0s.png)
无法在发生错误时创建会话,请检查 PHP 或网站服务器日志,并正确配置 PHP 安装最快的解决办法
一个基于flask的web应用诞生 bootstrap框架美化(3)
![](https://img.aspxhome.com/file/2023/8/86488_0s.png)
对Python中小整数对象池和大整数对象池的使用详解
微信小程序仿今日头条导航栏滚动解析
SQL字符串处理函数大全
利用Golang生成整数随机数方法示例
Window环境下Scrapy开发环境搭建
![](https://img.aspxhome.com/file/2023/3/112153_0s.png)
python 自动化偷懒的四个实用操作
![](https://img.aspxhome.com/file/2023/3/63943_0s.jpg)
为什么相对PHP黑python的更少
python高手之路python处理excel文件(方法汇总)
![](https://img.aspxhome.com/file/2023/4/101664_0s.png)
golang 微服务之gRPC与Protobuf的使用
Django博客系统注册之创建用户模块应用
![](https://img.aspxhome.com/file/2023/0/97680_0s.png)