git 命令怎么退回到当前版本未修改之前的状态?

Posted 凯小默

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了git 命令怎么退回到当前版本未修改之前的状态?相关的知识,希望对你有一定的参考价值。

在此之前,我们先了解一下工作区和暂存区:

工作区(Working Directory)

就是你在电脑里能看到的目录,比如下面的 learngit 文件夹就是一个工作区:

暂存区

工作区有一个隐藏目录 .git,这个不算工作区,而是Git的版本库(Repository)

Git 的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有 Git 为我们自动创建的第一个分支 master,以及指向 master 的一个指针叫 HEAD

git add 把文件添加进去,实际上就是把文件修改添加到暂存区;

git commit 提交更改,实际上就是把暂存区的所有内容提交到当前分支。

总的来说就是需要提交的文件修改通通放到暂存区,然后,一次性提交暂存区的所有修改。

下面开始正题,要退回到当前版本需要分情况

1、没有 add(没有添加到暂存区)

这里只有一步就是:丢弃工作区的修改

撤销一个文件修改:

git checkout -- 文件名

撤销全部文件修改:

git checkout -- .

2、已经 add,但是没有 commit(已经添加到暂存区)

第一步:撤销暂存区的文件(撤销add)

把暂存区的修改撤销掉(unstage),重新放回工作区:

git reset HEAD <file>

撤销这次所有暂存区的文件

git reset HEAD .

第二步:丢弃工作区的修改

这个就是跟 没有 add(没有添加到暂存区) 的处理一样:

撤销一个文件修改:

git checkout -- 文件名

撤销全部文件修改:

git checkout -- .

参考资料

以上是关于git 命令怎么退回到当前版本未修改之前的状态?的主要内容,如果未能解决你的问题,请参考以下文章

git reset回退版本后怎么恢复到当前版本

git --- stash用法

Git 版本回退命令

git回退之前版本

git还原某个特定的文件到之前的版本

手把手教你如何操作git回退版本(图文并茂)