文档章节

git reset

秋风醉了
 秋风醉了
发布于 2015/08/25 11:05
字数 1042
阅读 113
收藏 1

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========

© 著作权归作者所有

共有 人打赏支持
秋风醉了
粉丝 236
博文 578
码字总数 419420
作品 0
朝阳
程序员
git revert 和reset的区别

这里讲一下git revert和git reset的区别: git revert 是撤销某次操作,此次操作之前的commit都会被保留 git reset 是撤销某次提交,但是此次之后的修改都会被退回到暂存区 具体一个例子,假...

mingkaidox
2013/07/16
0
6
git 撤销操作 git reset与git revert的使用

先简单说一下,在提交到远程库之前我们使用git reset 命令完全可以满足我们 撤销操作的需求,如果操作已经提交到远程库,那只好使用 git revert 来提交一个新的撤销操作 撤销 需要撤销的那次...

悟_空
2017/12/15
0
0
Git的基本概念和用法

在日常使用GIT过程中,经常会出错,比如无意间丢失了未提交的数据,回退版本时丢失了工作目录,等等。经过思考发现,所有这些错误都是因为对GIT中一些基本的概念模糊而导致,因为对一些基本概...

jims
2016/10/01
33
0
git 推送远程分支

Command line instructions HTTPS 本地分支已经建立,与远程分支联系。 删除与远程分支的关联git remote rm origin 回退版本 git reset –hard:彻底回退到某个版本,本地的源码也会变为上一...

小墨雨
2017/04/01
3
0
git revert 与 git reset

Git版本回滚之 git revert 与 git reset 在使用 git 的时候,如果错误push之后,经常会回滚版本。 git的回滚有两种方式: revert命令:这种方式,是用一种反向的 push 来重新提交一次。git中...

evenyao
06/29
0
0

没有更多内容

加载失败,请刷新页面

加载更多

RESTful架构详解

1. 什么是REST REST全称是Representational State Transfer,中文意思是表述(编者注:通常译为表征)性状态转移。 它首次出现在2000年Roy Fielding的博士论文中,Roy Fielding是HTTP规范的主...

kitty1116
19分钟前
0
0
精通Spring Boot——第十篇:Quartz动态配置定时任务

定时任务简述 定时任务,在企业开发中尤其重要,很多业务都是需要定时任务去做的。比如说10点开售某件东西,凌晨0点统计注册人数,统计其他各种等等。这个时候不可能说让人为的去开启某个开关...

developlee的潇洒人生
22分钟前
0
0
将一些内容输出到文件中

看到一个面试题,如下: 第八题: 一个字符串将其输入到一个文件中,代码如下: <?php$a = '[{"teamId": "43", "serial": "1"},{"teamId": "1", "serial": "2"},{"teamId": "14", "serial":...

vinci321
30分钟前
0
0
nginx的简单使用:负载均衡

nginx:反向代理的服务器;用户发送请求到nginx,nginx把请求发送给真正的服务器,等待服务器处理完数据并返回,再把数据发送给用户。 nginx作为一个反向代理服务器,能缓存我们项目的静态文...

osliang
今天
2
0
网站title标题被改并被百度网址安全中心提醒的解决办法

国庆假日期间我们Sine安全接到众多网站站长求助网站标题被改导致在百度搜索中百度安全中心提醒被拦截,导致网站正常用户无法浏览网站被跳转到一些菠菜du博网站,而且很明显的一个特征就是在百...

网站安全
今天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部