git操作之三:git reset
在上篇文章中介绍了git restore命令,该命令的可以看作是撤销命令,文件在不同的状态下,使用git restore <file> 命令,会撤销对文件的修改,是文件回到修改前的状态也就是暂存区或者本地代码区,而使用git restore --staged <file>命令,则是使文件从暂存区回到工作区,且保留文件的修改。那么如果使文件从本地代码区移除那,或者说如何撤销已commit的文件那。
一、概述
通过前边的介绍,了解到使用git commit -m "提交说明" <file>可以把文件提交到本地代码库,如果是误提交,要把提交的文件撤回要使用git reset 命令。
二、详述
命令格式如下,
git reset [--hard | --mixed | --soft] HEAD^
git reset --hard
命令如下,
git reset --hard HEAD^/git reset --hard HEAD~1 其中HEAD^指的是后退一次提交,同理HEAD^^后退两次提交;HEAD~1 后退一次提交,HEAD~2 后退两次提交;
现在看下我的提交记录,
那么现在我执行下git reset --hard HEAD^命令,再看提交记录
从上图可以看到提交记录回到了上个版本,那么此刻文件的内容也发生变化。
现在又这样一种情况,如果在MyFirst.java、MyFirst2.java均提交的情况下,修改MyFirst.java、MyFirst2.java,然后把MyFirst2.java执行git add命令后再执行git reset --hard HEAD^命令后两个文件会发生什么变化,
现在两个文件的内容如下,
package cn.com.my; public class MyFirst {
public static void main(String[] args) {
System.out.println("a"); } }
package cn.com.my; public class MyFirst2 {
public static void main(String[] args) {
System.out.println("b");
}
}
再看下现在git的状态,
现在对MyFirst.java进行修改,但不执行git add 命令
package cn.com.my; public class MyFirst {
public static void main(String[] args) {
System.out.println("a");
System.out.println("修改未追踪"); } }
对MyFirst2.java,执行git add命令
package cn.com.my; public class MyFirst2 {
public static void main(String[] args) {
System.out.println("b");
System.out.println("修改且追踪");
}
}
现在看下git的状态,
现在执行git reset --hard HEAD~1命令,两个文件的内容如下,
package cn.com.my; public class MyFirst {
public static void main(String[] args) {
System.out.println("a");
System.out.println("提交后修改"); } }
package cn.com.my; public class MyFirst2 {
public static void main(String[] args) { }
}
对比下上面的文件,发现和上边的修改后的也不一样,这说明,git reset --hard HEAD~1 命令会回退到上个版本,中间做的修改会被撤销,包括在工作区中的修改和已放入暂存区的修改都会被撤销。
git reset --soft
现在看下git的状态,
可以看到没有待提交的文件也就是没有在暂存区的文件,现在修改MyFirst.java、修改MyFirst2.java并加入到暂存区,看下当前的状态,
可以看到MyFirst2.java在暂存区中等待commit,而MyFirst.java在工作区中未被追踪,看下两个文件的内容,
package cn.com.my; public class MyFirst {
public static void main(String[] args) {
System.out.println("a");
System.out.println("提交后修改");
System.out.println("MyFirst,2020-11-22");
System.out.println("MyFirst,2020-11-22-2"); } }
package cn.com.my; public class MyFirst2 {
public static void main(String[] args) {
System.out.println("MyFirst2,2020-11-22");
System.out.println("MyFirst2,2020-11-22-2");
}
}
下面执行git reset --soft HEAD~1命令,并查看git的状态,
可以看到在暂存区有MyFirst.java、MyFirst2.java两个文件,在工作区有MyFirst.java,在工作区有MyFirst.java可以理解,因为该文件被修改过未执行git add命令,回退和这个没关系。那么为什么MyFirst.java还会出现在暂存区那,因为git reset --soft HEAD~1命令,该命令会让版本回退一个版本,且在工作区和暂存区的文件不会发生改变,但是会把回退前的版本和回退后版本的差异放到暂存区,那么就好理解了,从MyFirst2.java说起,在回退前该文件做了修改并提交到了暂存区,回退后肯定也在暂存区,MyFirst.java在回退前进行了修改,但是没有保存到暂存区,在回退后,MyFirst.java回退到了上个版本,回退前和回退后会两个版本会有差异,这个差异在回退后被放到了暂存区,所以在暂存区肯定会出现MyFirst.java,为什么会有未追踪的MyFirst.java,因为回退前对其进行了修改未追踪该文件。
git reset --mixed/git reset
下面看最后一个参数--mixed或者说默认的参数
演示环境仍是下面的环境,对MyFirst.java进行修改且不追踪,对MyFirst2.java进行修改且添加到暂存区,
文件的内容如下,
package cn.com.my; public class MyFirst {
public static void main(String[] args) {
System.out.println("a");
System.out.println("提交后修改");
System.out.println("MyFirst,2020-11-22");
System.out.println("MyFirst,2020-11-22-2");
System.out.println("MyFirst,2020-11-22-3"); } }
package cn.com.my; public class MyFirst2 {
public static void main(String[] args) {
System.out.println("MyFirst2,2020-11-22");
System.out.println("MyFirst2,2020-11-22-2");
System.out.println("MyFirst2,2020-11-22-3");
}
}
下面执行git reset --mixed HEAD~1/git reset HEAD~1,查看git的状态
可以看到MyFirst.java和MyFirst2.java均未追踪,再看下文件的内容,
package cn.com.my; public class MyFirst {
public static void main(String[] args) {
System.out.println("a");
System.out.println("提交后修改");
System.out.println("MyFirst,2020-11-22");
System.out.println("MyFirst,2020-11-22-2");
System.out.println("MyFirst,2020-11-22-3"); } }
package cn.com.my; public class MyFirst2 {
public static void main(String[] args) {
System.out.println("MyFirst2,2020-11-22");
System.out.println("MyFirst2,2020-11-22-2");
System.out.println("MyFirst2,2020-11-22-3");
}
}
可以看到文件的内容和执行git reset HEAD~1前没有改变,git reset HEAD~1命令不会改变文件的内容,但在reset前所做的修改在reset后都会反应在工作区,具体表现未MyFirst2.java在reset前在暂存区,但reset后在工作区。
三、总结
git reset [--hard | --soft | --mixed] HEAD^命令总结如下,
git reset --hard HEAD^ 会撤销版本V-1到版本V间的修改,直接回退到版本V-1,无论所做的修改是否被追踪;
git reset --soft HEAD^ 在版本V-1到版本V间的修改均被保留,如一个文件已提交到暂存区,在回退后仍在暂存区;如一个文件在工作区,在回退后该文件修改前的内容在暂存区,修改后的内容仍在工作区;这时如果执行git commit -m <file> 命令,在暂存区的都会被commit(包括在后退前追踪的暂存区的内容);
git reset --mixed HEAD^ 在版本V-1到版本V间的修改均被保留,所有文件都在工作区,需重新被追踪;
下面是三张示意图,
有不正之处,欢迎指正,谢谢!
git操作之三:git reset的更多相关文章
- AS中Git操作和Git工作流
查阅并学习安卓中如何使用Git,并扩展学了下Gitflow工作流程,以下是我觉得有用,系统,详细的相关文章. AS中Git操作系列 https://www.jianshu.com/p/0cc226ee ...
- git操作之git clean删除一些没有git add的文件
删除 一些 没有 git add 的 文件: git clean 参数 -n 显示 将要 删除的 文件 和 目录 -f 删除 文件,-df 删除 文件 和 目录
- git 操作实践
git操作: - git是一个用于帮助用户实现版本控制的软件 #首先创建项目 1. cd到项目文件目录 2. 鼠标右键点击 Git Bash Here 3. git init #在项目文件目录生成 . ...
- git操作
svn终结,git时代来临 git是最好的分布式版本控制系统 廖雪峰的git讲的蛮不错,http://www.liaoxuefeng.com/wiki/0013739516305929606dd183 ...
- 代码回滚:git reset、git checkout和git revert区别和联系
git reset.git checkout和git revert是你的Git工具箱中最有用的一些命令.它们都用来撤销代码仓库中的某些更改,而前两个命令不仅可以作用于提交,还可以作用于特定文件. 因为 ...
- git操作笔记
首先本文参考廖雪峰的git学习教程,写的非常好,值得学习. http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b80 ...
- 关于git 操作
一. Git 命令初识 在正式介绍Git命令之前,先介绍一下Git 的基本命令和操作,对Git命令有一个总体的认识 示例:从Git 版本库的初始化,通常有两种方式: 1)git clone:这是一种较 ...
- Git详解之三 Git分支
相关文档 — 更多 Git 基础培训.ppt GIT 使用经验.ppt GIT 介绍.pptx GIT 分支管理是一门艺术.docx Eclipse上GIT插件EGIT使用手册.docx git/gi ...
- 2015年12月02日 GitHub入门学习(四)Git操作
序,学习使用Git是一项新技能,你将了解到Git与SubVersion的区别. 一.基本操作 git init 初始化仓库,请实际建立一个目录并初始化仓库,.git目录里存储着管理当前目录内容所需的仓 ...
随机推荐
- linux(centos8):zabbix配置邮件报警(监控错误日志)(zabbix5.0)
一,zabbix5.0发邮件报警的准备工作: zabbix5.0在linux平台上的安装:参见这一篇: https://www.cnblogs.com/architectforest/p/129125 ...
- 一文读懂MySQL的事务隔离级别及MVCC机制
回顾前文: 一文学会MySQL的explain工具 一文读懂MySQL的索引结构及查询优化 (同时再次强调,这几篇关于MySQL的探究都是基于5.7版本,相关总结与结论不一定适用于其他版本) 就软件开 ...
- 【应用程序见解 Application Insights】在Application Insights中通过自定义查询结果定义指标并显示在Dashboard中
问题情形 通过Application Insights收集到指标数据后,如Request,Trace,Exception.但是默认的Insights图表不能满足业务的需求,需要自定义相应的类SQL语句 ...
- C# 将dataset数据导出到excel中
//添加引用 NPOI.dll //添加 using NPOI.HSSF.UserModel; /// <summary> /// 导出数据到Excel /// </summary& ...
- Codeforces Round 662 赛后解题报告(A-E2)
Codeforces Round 662 赛后解题报告 梦幻开局到1400+的悲惨故事 A. Rainbow Dash, Fluttershy and Chess Coloring 这个题很简单,我们 ...
- 2020-2021-1 20209306 《linux内核原理与分析》第三周作业
目录 一.实验:完成一个简单的时间片轮转多道程序内核代码 二.学习总结 1.堆栈相关的寄存器 2.堆栈操作 3.其他关键寄存器 4.用堆栈来传递函数的参数 5.了解了函数如何传递返回值,堆栈还提供局部 ...
- Parquet 源码解析
date: 2020-07-20 16:15:00 updated: 2020-07-27 13:40:00 Parquet 源码解析 Parquet文件是以二进制方式存储的,所以是不可以直接读取的, ...
- 关于天线长度及LC值的计算
一.天线长度与波长 1.天线最佳长度计算 理论和实践证明,当天线的长度为无线电信号波长的1/4时,天线的发射和接收转换效率最高.因此,天线的长度将根据所发射和接收信号的频率即波长来决定.只要知道对应发 ...
- python读取文件遇到问题及解决
用python的open()函数打开文件时, 1.文件写绝对路径报IOError: [Errno 2] No such file or directory.文件改为相对路径(只写文件名)解决该问题 2 ...
- Kubernetes 搭建 ES 集群(存储使用 local pv)
一.集群规划 由于当前环境中没有分布式存储,所以只能使用本地 PV 的方式来实现数据持久化. ES 集群的 master 节点至少需要三个,防止脑裂. 由于 master 在配置过程中需要保证主机名固 ...