一、分类
1.git reset --soft HEAD^
:温柔的回退。
2.git reset --mixed HEAD^
:中等回退。
3.git reset --hard HEAD^
:强硬的回退。
假设开始状态如下图:
二、看例子
1、git reset --soft
回退
假设版本从V4退回到V3时候如下:
只是把HEAD指针指向了V3版本。而工作区和暂存区中的readme.txt
文件是没有做任何变动的。想当于退回了git commit之前状态;若之后再commit提交则如下图所示:
如果我们使用git log
命令查看本地版本库的历史提交信息的时候,就不会出现V4版本提交的信息。会是V1
、V2
、V3
、V5
。
但是V4版本是不会在Git中删除的,会永远的存储在Git的本地版本库中。我们可以使用git reflog
命令,可以查看该V4版本的提交信息。
2、git reset --mixed
命令
此操作进分两步:
-
把HEAD指针指向了V3版本(也就是版本库回退了)。
-
把暂存区中的文件也回退到了V3版本。
只有工作区中的文件内容没有变化。
这说明命令比命令,多回退了暂存区中的内容。
就等于回滚到了和git add
之前的状态。
3、git reset --hard
命令
此操作进行了三步操作:
-
把HEAD指针指向了V3版本
-
把暂存区中的文件也回退到了V3版本。
-
把工作区中文件的修改也复原了。
所以执行完命令,是完全回退一个版本。
此时工作区、暂存区、本地版本库中的文件状态都是一致的,都是V3版本。
就等于回滚了一个“编辑文件,添加到暂存区,提交版本库”的整个流程。