Git学习笔记03-工作区和暂存区
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-工作区和暂存区的更多相关文章
- Git学习笔记二--工作区和暂存区
Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念. 简单理解: 我们使用mkdir Git在d盘下创建的文件夹,就是工作区,我们编辑readme.txt文件就是在工作区下完成的: gi ...
- [原]git的使用(二)---工作区和暂存区
接着上篇 git的使用(一) http://www.cnblogs.com/horizonli/p/5323363.html 6.工作区和暂存区(中转站) 工作区(Working Directory) ...
- 【Git】三、工作区、暂存区、版本库
一.基础概念 工作区:电脑中可以看到的目录,为电脑中的项目文件 暂存区:暂存修改的地方 版本库:存放项目的各个版本文件 二.详细介绍 工作区为我们工作所使用的目录,在工作区我们对项目文件进行增删改查. ...
- Git时光机穿梭之工作区和暂存区
Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念. 先来看名词解释. 工作区(Working Directory) 就是你在电脑里能看到的目录,比如我的learngit文件夹就是一个工 ...
- GIt学习第二天之版本回退、工作区和暂存区
搬运自 ‘廖雪峰的官方网站’ 地址:https://www.liaoxuefeng.com/ 1.版本回退 在Git中,我们用git log命令显示从最近到最远的提交日志,如果嫌输出信息太多,看得眼花 ...
- Git学习——工作区和暂存区
工作区就是我们的电脑上的git初始化目录.版本库就是我们工作区中的隐藏目录.git.版本库中分为两个部分:(1)stage(index)暂存区:git add <file>命令后file就 ...
- Git学习总结三(工作区和暂存区、撤销修改)
工作区和暂存区 工作区(Working Directory) 就是你在电脑里能看到的目录,比如我的learngit文件夹就是一个工作区: 版本库(Repository) 工作区有一个隐藏目录.git, ...
- git工作区、暂存区、版本库之间的关系
区分三者关系 Git最让你迷惑的无非是它里面的各种概念了,如果是刚开始接触Git希望看完本篇介绍之后有一个清晰的认识,笔者认识也有限这里只说说个人对使用Git的感受,说一下它里面的几个最常用的概念的理 ...
- git中的版本库,暂存区和工作区
- git(工作区,暂存区,管理修改,撤销修改,删除文件)
工作区和暂存区 984次阅读 Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念. 先来看名词解释. 工作区(Working Directory) 就是你在电脑里能看到的目录,比如我的l ...
随机推荐
- OS + Windows 10 / office excel vlookup / CredSSP
s https://support.microsoft.com/zh-cn/help/10749/windows-10-find-product-key 查找 Windows 7 或 Windows ...
- nginx 限速最容易理解的说明
nginx 限速研究汇报 写在前面 这两天服务器带宽爆了,情况如下图: 出于降低带宽峰值的原因,我开始各种疯狂的研究nginx限速.下面是我研究过程中的心得!(花了好几个小时的时间写的人生第一篇技术类 ...
- JAVA核心技术I---JAVA基础知识(类的继承)
一:基本概念同C++一致 二:继承演示 .将共同点提取出来,即形成了父类/基类/超类 –Parent class/Base class/Super class .而其他类则自动成为子类/派生类 –Ch ...
- java语音转文字
用到的百度提供的api 需要把wav音频文件转成16k的频率,必须转,不转百度api解析不出来.显示音频文件不清晰错误.想要转化还必须要有ffmpeg程序,这个自己百度去下载.然后拿转好的文件扔到百度 ...
- 基于Asp.net C#实现HTML转图片(网页快照)
一.实现方法 //WebSiteThumbnail.cs文件,在BS项目中需要添加对System.Windows.Forms的引用 using System; using System.Data; u ...
- c# 三种传参方式 in,out,ref
in:默认方式,传值不返回 out:不传值 但是会返回新值给予传参对象 ref:传存储地址,所以传参前必须赋值初始化,传值后的运算结果直接作用在传参上 Out和ref的效果差不多
- maven项目的聚合与继承
maven项目的聚合与继承: 一.聚合 如果我们想一次构建多个项目模块,那我们就需要对多个项目模块进行聚合 1.1.聚合配置代码 1 <modules> 2 <module>模 ...
- kindeditor<=4.1.5 文件上传漏洞利用
kindeditor<=4.1.5 文件上传漏洞 - Kindeditor <=4.1.5 file upload vulnerability and use 漏洞存影响版本:小于等于4. ...
- Coursera Deep Learning 2 Improving Deep Neural Networks: Hyperparameter tuning, Regularization and Optimization - week1, Assignment(Initialization)
声明:所有内容来自coursera,作为个人学习笔记记录在这里. Initialization Welcome to the first assignment of "Improving D ...
- IBM X3650 M5服务器RAID阵列设置
生产环境中的raid配置说明: 一. 开机后,注意引导界面,按F1键进入BIOS进行设置 二. 进入BIOS后,选择system setting--storage ,进入磁盘阵列配置界面,可以看到M5 ...