git学习(四):理解git暂存区(stage)

与一般的版本管理不同的是,git在提交之前要将更改通过git add 添加到暂存区才能提交(git commit)。即使是已经交给了git来管理的文件也是如此。这里继续学习git的暂存区。

通过git checkout撤销工作区更改

在版本库.git目录下有一个index文件。

首先执行git checkout命令,撤销工作区中welcome.txt文件尚未提交的修改。

原来可以通过这种方法来撤销修改,妈呀,我还是菜啊。之前使用IDEA的时候只知道用revert。

git status和git diff原理

小实验:修改一个文件的时间戳,然后对应观察.git/index的时间戳。

结论:执行git status或者git diff扫描工作区改动时,

  1. 先根据.git/index文件中记录(用于跟踪工作区文件的)时间戳、长度等信息判断工作区文件是否改变。
  2. 如果工作区文件的时间戳改变了,说明文件的内容可能改变了,需要打开文件,读取文件的内容,与更改前的原始文件进行比较,判断文件内容是否被更改。
  3. 如果文件内容没有改变,则将文件新的时间戳记录到.git/index文件中。
  4. 因为如果判断文件是否更改,使用时间戳、文件长度等信息比较要比通过文件内容快得多。

.git/index

.git/index:

  • 包含了文件索引的目录树,像一个虚拟的工作区。
  • 目录树种记录了文件名和文件的状态信息(时间戳和文件长度等)。
  • 并不存储文件内容(内容在.git/objects中)。

工作区,暂存区和版本库说明

  • 左侧为工作区,右侧为版本库。在版本库中标记为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分支的全部或部分文件替换暂存区和工作区中的文件,比较危险。

原文地址:https://www.cnblogs.com/tuhooo/p/9185799.html

时间: 2024-10-15 05:07:36

git学习(四):理解git暂存区(stage)的相关文章

git学习 三 工作区和暂存区

工作区和暂存区 工作区(Working Directory) 就是你在电脑里能看到的目录,比如我的learngit文件夹就是一个工作区: 版本库(Repository) 工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库. Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD. 分支和HEAD的概念我们以后再讲. 前面讲了我们把文件往Git版本库里添加的时

Git学习02 --暂存区,撤销修改,删除文件

工作区和暂存区概念: 工作区(Working Directory)就是你在电脑里能看到的目录. 版本库(Repository) 工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库. Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD. 前面讲了我们把文件往Git版本库里添加的时候,是分两步执行的: 第一步是用git add把文件添加进去,实际上就是把文件

【Git】(1)---工作区、暂存区、版本库、远程仓库

工作区.暂存区.版本库.远程仓库 一.概念 1.四个工作区域 Git本地有四个工作区域:工作目录(Working Directory).暂存区(Stage/Index).资源库(Repository或Git Directory).git仓库(Remote Directory).文件在这四个区域之间的转换关系如下: Workspace: 工作区,就是你平时存放项目代码的地方 Index / Stage: 暂存区,用于临时存放你的改动,事实上它只是一个文件,保存即将提交到文件列表信息 Reposit

【git学习四】git基础之git为项目打标签

1.背景 今天学习了下如何给项目打标签,为此项目的修改标记版本号,然后可以直接推送版本号到服务器上,方便了很多,而且便于对项目进行管理. 2.打标签 1.查询已有标签,可以使用git tag命令,查询某个特定版本可以git tag -l 'v*' git tag 2.为版本创建标签 git tag -a v1.4 -m 'my version 1.4' 3.查看添加的标签,git show命令 git show 4.也可以对之前的某次commit加标签 git tag -a v1.2 9fceb

Git撤销暂存区stage中的内容

$ git add readme.txt提交到了stage中. $ git statusOn branch masterChanges to be committed:  (use "git reset HEAD <file>..." to unstage) modified:   readme.txt $ git reset HEADUnstaged changes after reset:M       readme.txt 小结: 1.当你乱改了工作区某个文件时,想直

Git学习笔记(2)——版本的回退,和暂存区的理解

本文主要记录了版本的回退,以及工作区,暂存区概念的理解. //开始之前,先回顾上次的内容,修改文件如下,并提交到版本库. Git is a distributed version control system. Git is free software distributed under the GPL. 1.查看版本库的信息 [email protected]:~/joe/learngit$ git log //可以看到,下面有3个版本 commit 71038bf6cbd05ef559549

完整学习git二 git 暂存区

1 git log 命令查看提交日志信息 git log --pretty-fuller #详细查看 git log --stat #查看每次提交的文件变更 git log --pretty-online 2git diff 对比文件的修改信息 git diff HEAD  git add . 后与当前版本库的头指针比较 git diff --cached 或--staged 提交暂存区和版本库中的文件差异 git 命令是如何影响工作区和暂存区的 左侧为工作区 右侧为版本库 . 版本库中标记为i

Git暂存区之Git Diff魔法

在不同参数的作用下,git diff的输出并不相同.在理解了Git中的工作区,暂存区和版本库(当前分支)的最新版本分别是三个不同的目录树后,就非常好理解 git diff 的魔法般的行为了. 工作区,暂存区和版本库的目录树浏览 有什么办法能够像查看工作区一样直观地查看暂存区及HEAD中的目录树吗?对于HEAD指向的目录树,可以使用Git底层命令ls-tree来查看. $ git ls-tree -l HEAD 100644 blob bb2f2a2c99a6608b400a63a2acf44a4

git 教程(5)--工作区和暂存区

Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念. 工作区(working directory) 就是你在电脑里能看到的目录,比如我的learngit文件夹就是一个工作区: 版本库 (repository) 工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库. Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD. 分支和HEAD的概念我们