解决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中的操作了

  • 9
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要删除 stash,可以使用 `git stash drop` 命令。 语法: `git stash drop [<stash>]` 其,<stash> 是可选参数,用于指定要删除的 stash 的名称。如果不指定,默认删除最新的 stash。 例如: ``` $ git stash list stash@{0}: WIP on master: 049d078 added the index file stash@{1}: WIP on master: c264051 Revert "added file_size" stash@{2}: WIP on master: 21d80a5 added number to log $ git stash drop stash@{1} Dropped stash@{1} (c264051 Revert "added file_size") ``` 这样,stash@{1} 就被删除了。 ### 回答2: 要删除一个stash,可以使用以下命令: 1. 首先,运行`git stash list`命令,以查看当前存在的stash列表。这会列出所有已保存的stash,每个stash都有一个唯一的标识符(stash@{0},stash@{1}等)。 2. 从stash列表选择要删除的stash标识符,然后运行以下命令:`git stash drop <stash标识符>`。例如,如果要删除stash@{0},则运行`git stash drop stash@{0}`。 3. 运行上述命令后,Git会将选定的stash删除,并将其从stash列表移除。请注意,这个操作是不可逆的,删除的stash将无法恢复。 如果你想要删除所有的stash,可以运行`git stash clear`命令。这会将所有的stash都删除,并清空stash列表。 需要注意的是,删除stash不会影响stash保存的代码更改。你可以在删除stash之前,先使用`git stash apply`命令将stash的代码更改应用到当前工作区,然后再进行删除操作。这样可以确保你不会丢失任何重要的更改。 ### 回答3: 要删除 Git stash,可以使用以下命令: 1. 首先,使用以下命令列出当前所有的 stash: ```shell git stash list ``` 2. 确定要删除的 stash 的索引号,通常以 'stash@{n}' 形式表示(其,n 是一个数字)。 3. 输入以下命令删除指定的 stash: ```shell git stash drop stash@{n} ``` 这将永久删除该 stash,不可恢复。请确保删除正确的 stash,以免丢失重要的更改。 另外,可以使用以下命令删除所有的 stash: ```shell git stash clear ``` 这将删除所有的 stash 记录,并且同样也是不可恢复的操作。 总结起来,删除 Git stash 的步骤如下: 1. 列出所有的 stash:`git stash list` 2. 确定要删除的 stash 的索引号(stash@{n})。 3. 删除指定的 stash:`git stash drop stash@{n}` 或者 删除所有的 stash:`git stash clear`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值