你的方法是完全错误的。您正在修改您不想修改的内容:您当前的分支(大概是master)。
一个简单的线性 git 存储库是这样的提交链
*---A---*---*---B---*---*---C
    ^                       ^
    |                       |
  master              origin/master
    ^
    |
   HEAD
那是您调用后存储库的状态git fetch。请注意,包含所有中间步骤的整个历史记录都在您的本地硬盘上。只是您只有在提交时A签出的状态(HEAD指向master哪个指向A),因此您看到的文件属于该状态。
现在,如果您只想查看提交为 的状态B,您可以使用 来查看该提交git checkout B。这会将您看到的文件更新为 的状态B,并指向HEAD该提交:
*---A---*---*---B---*---*---C
    ^           ^           ^
    |           |           |
  master       HEAD   origin/master
HEAD始终引用git认为您所在的提交/分支,并且在您调用git status.
git checkout B如果您只想查看该提交,那么简单就足够了。如果您确实想要做出您提交并想要保留的更改,您应该引入一个新分支来记录这些更改。这是通过一个简单git checkout -b newBranch的之后实现的git checkout B。这会给你状态
*---A---*---*---B---*---*---C
    ^           ^           ^
    |           |           |
  master    newBranch origin/master
                ^
                |
               HEAD
这只是给出了一个提交的名称,B而不是它的哈希值。在更多提交之后,您的状态将如下所示:
*---A---*---*---B---*---*---C
    ^           |           ^
    |           |           |
  master         \    origin/master
                   \
                    *---*---D
                            ^
                            |
                        newBranch
                            ^
                            |
                           HEAD
关键是,在使用 签出其他分支/提交后,您始终可以通过调用git checkout ...轻松返回提交,并且永久引用停止垃圾收集提交。Dgit checkout newBranchgitD
现在,为什么使用git reset --hard不好?首先,它会破坏您尚未提交的所有本地更改,恕不另行通知。其次,如果您不小心,它可能会丢失您的历史记录。
例如,假设您在上次推送到上游存储库后进行了一些更改,并希望查看一些历史提交B。(与您的问题中的情况有些相反。)历史如下所示:
  *---A---*---*---B---*---*---C
      ^                       ^
      |                       |
origin/master               master
                              ^
                              |
                             HEAD
使用git reset --hard B,您将获得以下状态:
  *---A---*---*---B-(-*---*---C )
      ^           ^
      |           |
origin/master   master
                  ^
                  |
                 HEAD
括号中的提交不再被任何分支直接或间接引用,并且可能随时被垃圾收集。git垃圾收集可能不是很激进,但如果它在你处于这种状态时进行垃圾收集,你就没有办法C收回提交,它将永远丢失。您不希望这种情况发生,因此养成git reset --hard轻率使用的习惯并不是一个好主意。
如果您git checkout改用,分支master仍将指向C,您仍然可以使用简单的git checkout master.