1

我有一个本地 git 存储库,在那里我对文件进行了一些实质性的编辑file1.txt

然后我发出了一些git命令来查看这个文件(和其他文件)的旧版本。我完全忘记了这一点——当然!- 会将旧版本写入我刚刚编辑过的同一个文件!

我发出的命令是

  • 一些git log ...命令
  • 一些git checkout <COMMIT> file1.txt命令
  • 一些git checkout <COMMIT>命令
  • 一个git status命令
  • git switch -而一git switch命令
  • 最后的git checkout master命令。

我认为这些命令中的任何一个都没有警告我它们会覆盖我未提交的更改。(不过,我确实得到了有关“分离 HEAD 模式”的信息。)

所以我希望有机会取回未提交的更改。git在签出旧版本之前是否在某处保存未提交的更改?我可以检索我未提交的更改吗?

4

1 回答 1

1

当您这样做时,git checkout <COMMIT> file1.txt您删除了未提交的更改。这个命令告诉 git 去提交并将文件更新到那个时候的状态。

所有其他命令都会带来您未提交的更改。

git status还会向您显示您的更改是否仍然存在。

将来使用git stash或进行临时提交以保留您的更改。

于 2021-07-02T15:02:45.220 回答