文档章节

Git四种文件状态和索引

pmos
 pmos
发布于 2017/01/01 22:17
字数 934
阅读 570
收藏 0

【推荐】2019 Java 开发者跳槽指南.pdf(吐血整理) >>>

git的文件状态和git的索引息息相关,git的文件状态如下图所示:

1、git的文件有如下四种状态:

  •     Untracked(未跟踪)
  •     Unmodified(未修改)
  •     Modified(已修改)
  •     Staged(已暂存)

2、git的索引档案(index)

    2.1、首先创建一个文件夹,并且通过git init将其设置为git的工厂,之后我们查看一下.git文件夹。

    这个文件夹中有三个文件:HEAD,config,description。

    接下来我们回到上一级目录,创建一个文件a.txt,并且使用git add .将其添加到暂存区中。

    然后再到.git文件夹中查询一下文件:

    有没有发现多了一个index文件,这个文件就是git的索引文件,当我们在工作区中进行了任意的操作
    之后git都会向这个文件中输入操作信息,当我们用git status查询的时候,就会用index来和版本库
    中的最新版本进行比较,以此确定哪些文件是什么状态。

3、git的文件状态详解:

    在了解了index的索引档案之后,我们就开始研究几种状态了。

    首先,创建一个b.txt的文件,使用git status查询:

    此时索引区中已经有了一个新的文件b.txt,但是git却发现这个文件还没有被管理,

    就将其设置为Untracked状态,之后执行add:

    此时a.txt和b.txt都已经被git所识别,并且将这个操作添加到了index中,index又和当前的最高版本
    进行比较,发现这两个文件都没有在仓库中,所以就提示new file,目前的状态已经变成了 Staged状态。
    之后执行commit:

    当提交之后,版本库中的内容和index的内容完全一致,所以就提示没有任何修改发现,
    这也就是Unmodified状态。之后我们向b.txt中添加一些内容:

    此时这个添加操作会被记录在index中,而index和最新的版本不同,所以从Unmodified状态变更
    到了Modified状态。所以Modified状态就是已经被GIT管理但是进行过修改,此时通过add之后又会
    进入到Staged状态,通过commit之后再次到Unmodified状态。

    最后就是Unmodified怎么到Untracked状态呢?这种情况就是当GIT版本库中的文件直接被删除,但是

    当前文件夹没有被删除时会出现。使用如下命令:

git rm --cached b.txt

    该命令执行完git版本库中的内容会被删除,但当前文件夹中的b.txt会存在,可以通过git ls-files查询
    版本库中的内容:

    此时版本库中没有了b.txt而文件夹中却有,index首先发现文件夹中有个b.txt而自己不知道,所以将
    b.txt设置为Untracked状态,但是它还发现原来的索引库中还有b.txt的内容(注意这里是文件内容,
    不是文件),但是这个文件却不在了,所以将其设置为"deleted b.txt"的状态:

    此时由于index是通过文件的内容来检索的,所以我们只要把b.txt添加到Staged中,index就会发现
    没有任何的变化,所以又回到了Unmodified状态。

    这就是如何从Unmodified状态回到Untracked状态,如果我们执行的rm命令不带--cached:

git rm b.txt

    此时会把文件中的b.txt和git库中的都删除,就没有Untracked状态的文件。

    这就是git的四种状态和状态之间的转换,了解这个是学习git原理的基础。

© 著作权归作者所有

pmos
粉丝 13
博文 128
码字总数 213664
作品 0
其它
项目经理
私信 提问
Git & CocoaPods & 私有化,你不得不知的组件化基础!

Git 理解Git的设计思想和基本的工作原理,对更好的使用Git至关重要。 Git思想 直接记录快照,而非比较差异。和其他版本控制系统不同的是,Git存储数据时将数据看成小型的文件系统的一组快照,...

Owenli_千
2018/01/04
0
0
Git基础入门(一)Git基础概念

Git和传统版本控制系统的区别: 传统版本控制系统: 1、将数据保存的信息看作是一组基本文件和每个文件随时间逐步累积的差异 2、只记录发生改变的数据 3、每次克隆只获取最新的内容 Git: 1、...

红尘世间
2017/10/22
0
0
几张图让你彻底弄懂git工作流(一)

前提:现在好多开发者都用git作为版本控制,虽然很多人都在用,但是并不是所有人都知道为什么这样用。 git简史 git属于分布式版本控制,客户端并不只是提取最新版本文件快照,而是把代码仓库...

Li_小点
2018/05/18
0
0
Eclipse上GIT插件EGIT使用手册

一_安装EGIT插件 http://download.eclipse.org/egit/updates/ 或者使用Eclipse Marketplace,搜索EGit 二_使用EGIT前的配置 配置个人信息,最重要的是user.name和user.email l Preferences ...

吃鱼的虾米
2014/01/21
103
0
git三种状态 三种工作状态 git基本流程

Git 有三种状态,你的文件可能处于其中之一: 已提交(committed):已提交表示数据已经安全的保存在本地数据库中。 已修改(modified) :已修改表示修改了文件,但还没保存到数据库中。 已...

506554897
2017/10/19
0
0

没有更多内容

加载失败,请刷新页面

加载更多

采购单品汇总_华南.xlsx

import pandas as pdimport matplotlib.pyplot as pltimport matplotlib as mp1mp1.rcParams["font.family"] = "STFangsong"# 加载《销售》表数据df1 = pd.read_excel(r"C:\Us......

龙玉滕
今天
5
0
OSChina 周五乱弹 —— 一次四千 要4次还能多给一千

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 @这次装个文艺青年吧 :#今日歌曲推荐# 分享金志文的单曲《远走高飞》: 版权又回来了现在听歌得好几个软件 《远走高飞》- 金志文 手机党少年们...

小小编辑
今天
7
0
Spring Cloud Alibaba 实战(十) - Spring Cloud GateWay

> 本文主要内容是:为什么要使用网关,整合Gateway,Gateway核心学习:Route,Predicate,Filter,最后使用Gateway聚合微服务请求 先总结至此的架构 1 网关的价值 不使用网关行嘛? 各个请求直接打在...

JavaEdge
今天
4
0
【CKB.DEV 茶话会】第二期:聊聊 CKB 钱包和 Nervos DAO 全流程

CKB.DEV 茶话会第二期:聊聊 CKB 钱包和 Nervos DAO 全流程 为了鼓励更多优秀的开发者和研究人员参与到 CKB 的开发和生态建设中去,我们希望组织一系列 CKB Developer Seminar(CKB.DEV 茶话...

NervosCommunity
今天
4
0
聊聊rocketmq的HAClient

序 本文主要研究一下rocketmq的HAClient HAClient rocketmq-all-4.6.0-source-release/store/src/main/java/org/apache/rocketmq/store/ha/HAService.java class HAClient extends Serv......

go4it
昨天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部