git reset --hard HEAD^后显示more?的解决方案

Posted yannuo-666

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了git reset --hard HEAD^后显示more?的解决方案相关的知识,希望对你有一定的参考价值。

git reset --hard HEAD^后显示more?的解决方案

技术图片

 

 

在windows的cmd控制台下操作git,想要回滚到上一次提交,但是输入git reset --hard HEAD^后就显示more?,多按几次回车后就报错如下,如何解决呢?

1  fatal: ambiguous argument ‘HEAD
2  ‘: unknown revision or path not in the working tree.
3  Use ‘--‘ to separate paths from revisions, like this:
4  ‘git <command> [<revision>...] -- [<file>...]‘

这是因为cmd控制台中换行符默认是^,而不是 ,所以它的more?的意思是问你下一行是否需要再输入,而^ 符号就被当做换行符而被git命令忽略掉了。

解决方法有如下几种:
加引号:git reset --hard "HEAD^"
加一个^:git reset --hard HEAD^^
换成~:git reset --hard HEAD~ 或者 git reset --hard HEAD~1
~ 后面的数字表示回退几次提交,默认是一次

技术图片

 

 

当然还可以换成git bash,powershell等就不会出现这种问题了

 

以上是关于git reset --hard HEAD^后显示more?的解决方案的主要内容,如果未能解决你的问题,请参考以下文章

git 找回 git reset --hard HEAD 后的代码

git reset --hard HEAD 留下未跟踪的文件

git reset HEAD 与 git reset --hard HEAD的区别

git reset --soft,--hard的区别

如何撤消 git reset --hard HEAD~1?

git reset 命令详解