Git和其他版本控制工具不同的地方就是有暂存区的概念

工作区(Working Directory)

就是在电脑界面上能够看到的目录

版本库(Repository)

工作区下面有个一个.git文件夹,也就是上一篇文章git init之后生成的文件夹。这个就是版本库。Git的版本库里存了很多东西,其中最重要的称为stage的暂存区,还有GIt为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD。

将文件往GIt版本库里添加分为两步执行:

第一步是用git add将文件添加,实际上就是把文件从工作区添加到暂存区

第二步是用git commit提交更改,实际上就是把文件从暂存区的所有内存提交到当前分支

简单的理解就是把所有修改先放到暂存区上,然后一次性提交暂存区的所有修改。

现在来实验下看看,使用Git Bash需要先cd到版本库所在路径

git status查看工作区状态

git diff对比工作区和暂存区的不同

git diff --cached 对比暂存区和分支的不同

可以git diff 具体文件名,对比某个具体文件,上面是对比整个。

跟着上一文章,创建完版本库后,添加文件到版本库后不做任何操作,使用git status,这时提示工作区是干净的。

使用git diff和git diff --cached应该也都是没有提示不同的

在工作区下新增一个文件,就叫lesson.txt吧,写不写东西随意,如果要写内容请不要用windwos自带的记事本打开。请用别的文本编辑器

提示lesson.txt状态是untracked。因为还没有被添加过。使用git diff还是没有提示。我以为会提示啥的。貌似对比的是只对比已经add的文件

使用git add将leeson.txt提交到暂存区,然后在git status看下状态

提示有修改还没有提交到分支,再使用git diff,因为刚刚add所以肯定没有不同,所以没提示正确。

使用giit diff --cached看下暂存区和分支的对比

提示有一个新增的file

往lesson.txt里面新增或者修改内容,然后再git status一下

会有两个记录,第一个绿色的是提示我们,上次添加到暂存区的修改,还没有提交到版本库。第二个红色的是提示我们,有修改的内容,还有没有添加到暂存区。

使用git diff看下,可以提示的不同,显示的格式是Unix通用的diff格式

第一行diff -get a/lesson.txt b/lesson.txt   表示为git格式的diff,进行比较的是a版本(变动前)的文件和b版本(变动后)的文件

第二行表示两个版本git哈希值(index区域的ff3de11对象,bcd74af这个是工作区的对象,最后六位数是对象的模式)

第三第四行 ---表示变更前的版本  +++表示变更后的版本

之后的行都是diff格式展示的内容

现在git commit一下,把暂存区的内容提交到分支,备注一下新增lesson.txt文件。

使用git diff --cached对比一下暂存区和分支,应该不会提示不同。

最后git add一下lesson.txt,把修改后的添加到暂存去,然后git diff对比下。然后git commit。

Git学习笔记03-工作区和暂存区的更多相关文章

  1. Git学习笔记二--工作区和暂存区

    Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念. 简单理解: 我们使用mkdir Git在d盘下创建的文件夹,就是工作区,我们编辑readme.txt文件就是在工作区下完成的: gi ...

  2. [原]git的使用(二)---工作区和暂存区

    接着上篇 git的使用(一) http://www.cnblogs.com/horizonli/p/5323363.html 6.工作区和暂存区(中转站) 工作区(Working Directory) ...

  3. 【Git】三、工作区、暂存区、版本库

    一.基础概念 工作区:电脑中可以看到的目录,为电脑中的项目文件 暂存区:暂存修改的地方 版本库:存放项目的各个版本文件 二.详细介绍 工作区为我们工作所使用的目录,在工作区我们对项目文件进行增删改查. ...

  4. Git时光机穿梭之工作区和暂存区

    Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念. 先来看名词解释. 工作区(Working Directory) 就是你在电脑里能看到的目录,比如我的learngit文件夹就是一个工 ...

  5. GIt学习第二天之版本回退、工作区和暂存区

    搬运自 ‘廖雪峰的官方网站’ 地址:https://www.liaoxuefeng.com/ 1.版本回退 在Git中,我们用git log命令显示从最近到最远的提交日志,如果嫌输出信息太多,看得眼花 ...

  6. Git学习——工作区和暂存区

    工作区就是我们的电脑上的git初始化目录.版本库就是我们工作区中的隐藏目录.git.版本库中分为两个部分:(1)stage(index)暂存区:git add <file>命令后file就 ...

  7. Git学习总结三(工作区和暂存区、撤销修改)

    工作区和暂存区 工作区(Working Directory) 就是你在电脑里能看到的目录,比如我的learngit文件夹就是一个工作区: 版本库(Repository) 工作区有一个隐藏目录.git, ...

  8. git工作区、暂存区、版本库之间的关系

    区分三者关系 Git最让你迷惑的无非是它里面的各种概念了,如果是刚开始接触Git希望看完本篇介绍之后有一个清晰的认识,笔者认识也有限这里只说说个人对使用Git的感受,说一下它里面的几个最常用的概念的理 ...

  9. git中的版本库,暂存区和工作区

  10. git(工作区,暂存区,管理修改,撤销修改,删除文件)

    工作区和暂存区 984次阅读 Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念. 先来看名词解释. 工作区(Working Directory) 就是你在电脑里能看到的目录,比如我的l ...

随机推荐

  1. saltstack grains

    saltstack的grains类似于ansible的setup模块,主要作用为手机客户端的主机基本信息(cpu,内核,os,virtual等),定义在客户端 [root@k8s_master ~]# ...

  2. SVN简单的使用

    一.什么是SVN有什么用? SVN是Subversion的简称,是一个开放源代码的版本控制系统.主要是用于团队开发中的资源共享和团队协作. 二.SVN服务器的安装 1.下载安装文件 在下面地址下载Vi ...

  3. Journal Storage Directory not formatted

    类型一: 当你从异常信息中看到JournalNode not formatted,如果在异常中看到三个节点都提示需要格式化JournalNode. 如果你是新建集群,你可以重新格式化NameNode, ...

  4. MyBatis-Configuration

    一.引用 properties 配置文件 db.properties driver=com.mysql.cj.jdbc.Driver url=jdbc:mysql://192.168.8.136:33 ...

  5. ContentType组件

    django提供的一个快速连表操作的组件 适用于:一个字段确定不了唯一: 如:pricepolicy表中,course_id和content_type中对应的课程类型id才能确定唯一: model.p ...

  6. 阅读:ECMAScript 6 入门(4)

    参考 ECMAScript 6 入门 ES6新特性概览 ES6 全套教程 ECMAScript6 (原著:阮一峰) JavaScript 教程 重新介绍 JavaScript(JS 教程) 数组的扩展 ...

  7. HDU - 1540 Tunnel Warfare(线段树区间合并)

    https://cn.vjudge.net/problem/HDU-1540 题意 D代表破坏村庄,R代表修复最后被破坏的那个村庄,Q代表询问包括x在内的最大连续区间是多少. 分析 线段树的区间内,我 ...

  8. SQL Server2012安装流程

    今天手比较抽风,把原来的SQL Server给卸载了,卸载还卸了半天,真是…… 安装时找了好多教程,结果都不是很详细,然后准备自己摸索一下,把这个过程记录下来,供大家参考,如果有不当的地方,欢迎指正, ...

  9. IIS Express URL Rewrite无效

    点击一下项目,再选择属性选项卡(不是右键属性) 如上图,如果托管管道模式是集成的话,改为经典即可.如果在vs2010的 WebDev.WebServer40方式启动 默认就是经典模式

  10. [C++]PAT乙级1003. 我要通过!(17/20)

    /* 1003. 我要通过!(20) “答案正确”是自动判题系统给出的最令人欢喜的回复.本题属于PAT的“答案正确”大派送 —— 只要读入的字符串满足下列条件,系统就输出“答案正确”,否则输出“答案错 ...