git restore 思考
restore
: 还原
举一个例子:
1 . 在一个文件夹中执行如下步骤 新建一个haha.txt
并提交
#初始化git
$ git init
#新建haha.txt
$ echo "Hello,Git" > haha.txt
#将haha.txt放进暂存区
$ git add haha.txt
#提交haha.txt
$ git commit -m "第一次提交haha.txt"
2.现在删除haha.txt
#删除haha.txt
$ git rm -f haha.txt
3.如果此时还原haha.txt
,直接使用git restore haha.txt
的话,会报如下错误
$ git restore haha.txt
error: pathspec 'haha.txt' did not match any file(s) known to git
-
为什么会这样?
-
因为执行完 3 后,
git rm -f haha.txt
还存在于暂存区,如果此时使用git restore haha.txt
从仓库中恢复haha.txt
就会很矛盾(如果能恢复,但是恢复之后暂存区里的删除指令提交了呢?
4.最终解决方案
#撤销暂存区删除haha.txt指令
$git restore --staged haha.txt
#从仓库中恢复haha.txt
$ git restore haha.txt