文档章节

git reset

秋风醉了
 秋风醉了
发布于 2015/08/25 11:05
字数 1042
阅读 105
收藏 1
点赞 0
评论 0

git reset

如下所示的三次提交

commit 61dda81e8d2414bc2415d55c66f11889fc3c5f80
Author: Yale Li <hellolyx1618@gmail.com>
Date:   Tue Aug 25 10:32:52 2015 +0800

    third commit

commit 489f1fa75ae537ce09bebdf121a18407827e7928
Author: Yale Li <hellolyx1618@gmail.com>
Date:   Tue Aug 25 10:31:59 2015 +0800

    second commit

commit 5886426c4c12f8546496afe45edd06669c4a7863
Author: Yale Li <hellolyx1618@gmail.com>
Date:   Tue Aug 25 10:31:07 2015 +0800

    first commit

使用git reset进行回退和撤销操作,git reset有可选的三个参数

根据–soft –mixed –hard,会对working tree和index和HEAD进行重置:

  1. git reset –mixed:此为默认方式,不带任何参数的git reset,即时这种方式,它回退到某个版本,只保留源码,回退commit和index信息

  2. git reset –soft:回退到某个版本,只回退了commit的信息,不会恢复到index file一级。如果还要提交,直接commit即可

  3. git reset –hard:彻底回退到某个版本,本地的源码也会变为上一个版本的内容

git reset -soft :取消了commit  

git reset -mixed(默认) :取消了commit ,取消了add

git reset -hard :取消了commit ,取消了add,取消源文件修改

=================

使用git reset --soft

sample git:(master) git reset --soft HEAD~2
➜  sample git:(master) ✗ git log
commit 5886426c4c12f8546496afe45edd06669c4a7863
Author: Yale Li <hellolyx1618@gmail.com>
Date:   Tue Aug 25 10:31:07 2015 +0800

    first commit

通过log可以看到回退到了第一次commit,soft模式回退了本地仓库的HEAD指针,没有回退暂存区域,也就是说直接commit还可以恢复提交,当运行git status时,可以看到有提示说

➜  sample git:(master) ✗ git status
On branch master
Changes to be committed:
  (use "git reset HEAD <file>..." to unstage)

	modified:   hello.txt

我们直接来运行git commit来恢复提交,

➜  sample git:(master) ✗ git commit -m 'recover'
[master 103612f] recover
 1 file changed, 2 insertions(+), 1 deletion(-)
➜  sample git:(master) git log
commit 103612f4dc4f1ee5552977811f85a04cd28d6322
Author: Yale Li <hellolyx1618@gmail.com>
Date:   Tue Aug 25 10:37:27 2015 +0800

    recover

commit 5886426c4c12f8546496afe45edd06669c4a7863
Author: Yale Li <hellolyx1618@gmail.com>
Date:   Tue Aug 25 10:31:07 2015 +0800

    first commit
➜  sample git:(master) vi hello.txt

同时文件的内容也恢复了,但两次的提交信息没有回复。


使用git reset --hard

现在的git log,

commit 103612f4dc4f1ee5552977811f85a04cd28d6322
Author: Yale Li <hellolyx1618@gmail.com>
Date:   Tue Aug 25 10:37:27 2015 +0800

    recover

commit 5886426c4c12f8546496afe45edd06669c4a7863
Author: Yale Li <hellolyx1618@gmail.com>
Date:   Tue Aug 25 10:31:07 2015 +0800

    first commit

通过git reset --hard 可以直接回退到第一次提交后的工作区域,直接舍弃暂存区域的修改。

➜  sample git:(master) git reset --hard HEAD~1
HEAD is now at 5886426 first commit

同时文件的内容也回退到第一次提交后的内容。

但是要注意:

当在push代码以后,使用git reset --hard <commit...> 回退代码到某个版本之前,但是这样会有一个问题,你线上的代码没有变,线上commit,index都没有变,当你把本地代码修改完提交的时候你会发现全是冲突.....这种情况要使用git revert


使用git reset --mixed

此为默认方式,不带任何参数的git reset,即时这种方式,它回退到某个版本,只保留源码,回退commit和index信息。

现在的log信息,

commit 58add32d2dcd0598c1bfba0dea2dbb6575b87096
Author: Yale Li <hellolyx1618@gmail.com>
Date:   Tue Aug 25 10:48:36 2015 +0800

    second commit

commit 5886426c4c12f8546496afe45edd06669c4a7863
Author: Yale Li <hellolyx1618@gmail.com>
Date:   Tue Aug 25 10:31:07 2015 +0800

    first commit

运行git reset --mixed

➜  sample git:(master) git reset --mixed HEAD~1
Unstaged changes after reset:
M	hello.txt
➜  sample git:(master) ✗ git status
On branch master
Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git checkout -- <file>..." to discard changes in working directory)

	modified:   hello.txt

no changes added to commit (use "git add" and/or "git commit -a")

运行git log会发现第二次的提交信息没有了,但是文件的内容还在,标记为 modified。


使用git reset HEAD <file>取消暂存

效果如下,

➜  sample git:(master) ✗ git status
On branch master
Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git checkout -- <file>..." to discard changes in working directory)

	modified:   hello.txt

no changes added to commit (use "git add" and/or "git commit -a")
➜  sample git:(master) ✗ git add hello.txt
➜  sample git:(master) ✗ git status
On branch master
Changes to be committed:
  (use "git reset HEAD <file>..." to unstage)

	modified:   hello.txt

➜  sample git:(master) ✗ git reset HEAD hello.txt
Unstaged changes after reset:
M	hello.txt
➜  sample git:(master) ✗ git status
On branch master
Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git checkout -- <file>..." to discard changes in working directory)

	modified:   hello.txt

no changes added to commit (use "git add" and/or "git commit -a")


使用git checkout -- <file>舍弃修改

效果如下

➜  sample git:(master) ✗ git checkout -- hello.txt
➜  sample git:(master) vi hello.txt

========END========

© 著作权归作者所有

共有 人打赏支持
秋风醉了
粉丝 223
博文 581
码字总数 411013
作品 0
东城
程序员

暂无相关文章

Python爬虫,抓取淘宝商品评论内容

作为一个资深吃货,网购各种零食是很频繁的,但是能否在浩瀚的商品库中找到合适的东西,就只能参考评论了!今天给大家分享用python做个抓取淘宝商品评论的小爬虫! 思路 我们就拿“德州扒鸡”...

python玩家 ⋅ 17分钟前 ⋅ 0

MySQL 内核深度优化

MYSQL数据库适用场景广泛,相较于Oracle、DB2性价比更高,Web网站、日志系统、数据仓库等场景都有MYSQL用武之地,但是也存在对于事务性支持不太好(MySQL 5.5版本开始默认引擎才是InnoDB事务...

java高级架构牛人 ⋅ 39分钟前 ⋅ 0

用户登录信息-钉子效果(基于jquery2.0)

本js效果使用jquery2.0,清晰的分解用户登录信息的(钉子效果),该效果直接用在作者网站(www.phpkhbd.com)上。 里面的难点有:定时器,延时。 大致效果如下: 一开始: 鼠标放上去的时候:...

宁哥实战课堂 ⋅ 40分钟前 ⋅ 0

解决yum安装报错Protected multilib versions

使用yum安装报错Protected multilib versions原因是因为多个库不能共存,不过更新的话也并不行,但是可以在安装命令后面加上如下一段命令: --setopt=protected_multilib=false 案例: 比如需...

北岩 ⋅ 51分钟前 ⋅ 0

为什么要学习Typescript???

简单来说 目前的typescript就是未来的javascript 为什么?? 这要从ECMA-262标准的第4版说起 对了 我们说的ES5 其实是ECMAScript3.1这个替代性建议被扶正了而已... 那么 第4版标准是什么? 看看...

hang1989 ⋅ 56分钟前 ⋅ 0

linux安装ipfs

一、下载ipfs # cd /usr/local/ipfs/ # wget https://dist.ipfs.io/go-ipfs/v0.4.15/go-ipfs_v0.4.15_linux-amd64.tar.gz # tar -zxvf go-ipfs_v0.4.15_linux-amd64.tar.gz 二、安装ipfs # ......

八戒八戒八戒 ⋅ 今天 ⋅ 0

jvm程序执行慢诊断手册

生产环境最多的几种事故之一就是程序执行慢,如果是web服务的话,表现就是响应时间长。本文分享,从业多年形成的排查守则。 诊断步骤 系统资源查看 首先是系统资源查看,而且必须是在第一步。...

xpbob ⋅ 今天 ⋅ 0

YII2 advanced 高级版本项目搭建-添加API应用以及多应用

一、YII安裝 安裝yii可以用composer安裝,也可以在yii中文社区下载归档文件安装 composer安装就不介绍了,因为要安装composer,比较麻烦,当然安装了composer是最好的,以后安装yii的插件要用...

botkenni ⋅ 今天 ⋅ 0

在jdk1.8的环境下模拟永久代内存溢出

相信不少小伙伴在看深入理解Java虚拟机的时候,作者给我们举例一个demo来发生PermGen space 1、通过List不断添加String.intern(); 2、通过设置对应的-XX:PermSize与-XX:MaxPermSize(更快看到...

虾几把写 ⋅ 今天 ⋅ 0

开发OpenDaylight组件的完整流程

在前面介绍学习了OpenDaylight的几个重要模块后,这里再来介绍下完整开发一个模块的过程。 OSGI的bundles提供被其他OSGI组件调用的服务。这个教程中展示的是Data Packet Service去解析数据包...

wangxuwei ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部