解决Git中Stash丢失

还记得前段时间,我写了两天的一个功能,眼看着写好了准备Push到主分支时(这里我用的GitDeskTop可视化软件),不知道是哪里出了问题,我从主分支Pull下来时,GitDeskTop先把我这两天的操作记录先放在了stash,但是不知道是那个地方出了问题,出现了这个错误“出现:A lock file already exits in the repository,which blocks this operation from completing.”,意思就是把我的git锁住了,我以前从来没遇见过,我就没管,然后我就关了这个提示,我就进行Restore操作,把我的前两天写好的功能恢复,可是点击Restore后神奇的一幕发生了,我前两天写的代码并没有Restore回来,但是我又没进行Commit操作,直接给吓坏了,两天工作量白干;(因此记得一定一定做完一个功能做好先commit)。因此我就想着可不可以恢复,因为没有进行commit,所以恢复起来很麻烦,不过还真让我找到了,参考了大量别人的博客后,我就进行了整合,说说我是怎么一步一步进行操作的

一:首先先说我当时出的错误,git被锁住的解决办法Git被锁

二:恢复丢失的Stash,通过git fsck --unreachable或者git fsck -- lost -found命令(这里我使用的是git fsck -- lost -found命令),通过git show+一条一条的对commit的记录进行查看(我是这样的),当你查看到时你丢失的记录时,进行git statsh apply+版本号的操作;参考这里两篇文章https://www.jianshu.com/p/59f30cc47db1https://zhuanlan.zhihu.com/p/660023218

三:恢复报错,当我在使用git statsh apply+版本号命令时,出现了这个错误“fatal: this operation must be run in a work tree”,(可能是因为分支的原因)参考这篇文章

工作树icon-default.png?t=N7T8https://www.cnblogs.com/lxd670/p/17550490.html

 当你自己手动添加工作树时,记得要添加正确的路径(因为我就是添加错了工作树路径导致我整个git都打不开),不过可以在这里手动修改

当修改了正确的工作数路径后我就可以进行git statsh apply+版本号操作,恢复了我stash中的操作了

猜你喜欢

转载自blog.csdn.net/qq_62947569/article/details/135385393
今日推荐