git三个区域详解
一、可以将git简单的分为三个区域 
   1、工作区(working directory) 
   2、暂缓区(stage index) 
   3、历史记录区(history)
二、三个区域关系:工作区是我们能看到的区域,我们在工作区修改增加代码;完成编辑后,我们用git add 将工作区文件添加到暂存区;然后利用git commit 提交文件到我们自己的分支。
操作命令如下:
1.git checkout --files或者git checkout . ,把文件从暂存区域复制到工作目录,用来丢弃工作区修改,不改变暂存区;
2.工作区添加文件到暂存区 git add files 或者git add . , .代表全部文件;
3.git reset -- files 或者git reset .清空暂存区文件,不改变工作去;
4.当执行 git rm --cached files 命令时,会直接从暂存区删除文件,工作区则不做出改变.
关于git reset:
命令格式:git reset [--soft | --mixed | --hard] [<commit>]
1)使用参数--hard,如git reset --hard <commitID>
①替换引用的指向。引用指向新的提交ID。
②替换暂存区。替换后,暂存区的内容和引用指向的目录树一致。
③替换工作区。替换后,工作区的内容变得和暂存区一致,也和HEAD所指向的目录树内容相同。
2)使用参数--soft,如 git reset --soft <commitID>
即只更改引用的指向,不改变暂存区和工作区。
3)使用参数--mixed或者不使用参数(默认为--mixed),如 git reset <commit>
更改引用的指向及重置暂存区,但是不改变工作区。
git reset 或者git reset HEAD
仅用HEAD指向的目录树重置暂存区,工作区不会受到影响,相当于将之前用git add 命令更新到暂存区的内容撤出暂存区。引用也未改变,因为引用重置到HEAD相当于没有重置。
git reset -- filename 或者 git reset HEAD filename
仅将文件filename 的改动撤出暂存区,暂存区中其他文件不改变。相当于命令git add filename 的反射操作。
git reset --soft HEAD^
工作区和暂存区不改变,但是引用向前回退一次。当对最新的提交说明或者提交的更改不满意时,撤销最新的提交以便重新提交。git reset HEAD^或者git reset --mixed HEAD^
工作不改变,但是暂存区会回退到上一次提交之前,引用也会回退一次。
git reset --hard HEAD^
彻底撤销最近的提交。引用回退到前一次,而且工作区和暂存区都会回退到上一次提交的状态。自上一次以来的提交全部丢失。
三、远程操作
显示配置了哪些远程服务器: $ git remote
显示配置了哪些远程服务器,同时显示URL: $ git remote -v
显示远程 详细信息: $ git remote show origin
修改远程标识名字: $ git remote rename A B
删除远程配置: $ git remote rm A
增加一个远程配置: $ git remote add A git://github.com/paulboone/ticgit.git
git三个区域详解的更多相关文章
- 学会Git玩转GitHub(第三篇) 入门详解 - 精简归纳
		学会Git玩转GitHub(第三篇) 入门详解 - 精简归纳 JERRY_Z. ~ 2020 / 10 / 25 转载请注明出处!️ 目录 学会Git玩转GitHub(第三篇) 入门详解 - 精简归纳 ... 
- Hexo系列(三) 常用命令详解
		Hexo 框架可以帮助我们快速创建一个属于自己的博客网站,熟悉 Hexo 框架提供的命令有利于我们管理博客 1.hexo init hexo init 命令用于初始化本地文件夹为网站的根目录 $ he ... 
- Windows系统Git安装教程(详解Git安装过程)
		Windows系统Git安装教程(详解Git安装过程) 今天更换电脑系统,需要重新安装Git,正好做个记录,希望对第一次使用的博友能有所帮助! 获取Git安装程序 到Git官网下载,网站地址: ... 
- 第15.29节 PyQt(Python+Qt)入门学习:containers容器类部件QScrollArea滚动区域详解
		老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 一.概述 Scroll Area提供了一个呈现在其他部件上的可滚动区域视图,滚动区域用于显示框架内的 ... 
- Android不规则点击区域详解
		Android不规则点击区域详解 摘要 今天要和大家分享的是Android不规则点击区域,准确说是在视觉上不规则的图像点击响应区域分发. 其实这个问题比较简单,对于很多人来说根本不值得做为一篇博文写出 ... 
- [转]hibernate三种状态详解
		本文来自 http://blog.sina.com.cn/u/2924525911 hibernate 三种状态详解 (2013-04-15 21:24:23) 转载▼ 分类: hibernate ... 
- 多表连接的三种方式详解 hash join、merge join、 nested loop
		在多表联合查询的时候,如果我们查看它的执行计划,就会发现里面有多表之间的连接方式.多表之间的连接有三种方式:Nested Loops,Hash Join 和 Sort Merge Join.具体适用哪 ... 
- elasticsearch系列三:索引详解(分词器、文档管理、路由详解(集群))
		一.分词器 1. 认识分词器 1.1 Analyzer 分析器 在ES中一个Analyzer 由下面三种组件组合而成: character filter :字符过滤器,对文本进行字符过滤处理,如 ... 
- Git的gitattributes文件详解
		转自:Git的gitattributes文件详解 Git的gitattributes文件是一个文本文件,文件中的一行定义一个路径的若干个属性. 1. gitattributes文件以行为单位设置一个路 ... 
随机推荐
- PRML 第二章mindmap
			PRML第二章的Mindmap,这一章读的比较快,主要是很多计算和证明的过程都跳过了,感觉不是特别需要认真去看每一个公式,能够记住每个小节的结论.公式就可以了.当然有能力.有时间的人还是可以认真读的, ... 
- 关于Two-Pass标记连通域个数
			关于Two-Pass标记连通域个数 背景 在完成图像的一系列处理后,得到二值图,一般会统计目标数量,即是获取连通域个数,这里采用TwoPass的方法. 基本思想 在Two-pass连通域标记中,第一次 ... 
- [读书笔记]python3.5实现socket通讯(UDP)
			UDP连接: 无连接,从一个端向另一端发送独立的数据分组 使用UDP连接的客户-服务器程序: UDPServer.py import socket serverPort = 50009 serverS ... 
- WEB典型应用
- (转帖)oracle sql 语句优化
			1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索 ... 
- PhpSrom安装xdebug
			1.php需要安装xdebug,这样能支持调试. 下载地址:http://www.xdebug.org/download.php,若不清楚下载版本,可将phpinfo的信息复制到下载地址页面的cust ... 
- Chapter 2 Open Book——38
			I looked around me to make sure it was clear. 我看了我周围一圈确定都是干净的. 我看看四周,以确认前后没有来车. That's when I notice ... 
- 【转】【Egit】如何将eclipse中的项目上传至Git
			1.下载egit插件 打开Eclipse,git需要eclipse授权,通过网页是无法下载egit的安装包的.在菜单栏依次打开eclipse→help→install new software→add ... 
- 【Python】使用super初始化超类
			初始化超类的传统方式,在子类的实例中调用超类的__init__()方法. 但是传统的方法有两个问题,比如: 问题1: class MyBaseClass: def __init__(self, val ... 
- 【转】如何将ACCESS数据库后缀名accdb改为mdb
			office 2007中的ACCESS数据库保存时,默认的后缀名是*.accdb, 但是在数据库编程中,用到的后缀名却是*.mdb, 不能直接将后缀名由 accdb 改为 mdb,虽然没有出错,但是编 ... 
