git master代码被删除 怎么恢复_git 找回git stash误删除的代码并恢复

问题

在一次分支切换中由于误操作将其他分支中的stash pop到了另一个分支,导致代码产生了非常多的冲突。还好当前分支改的不多直接dicard掉就好了,但是另一个的分支的stash就没有了,很多代码由于不想直接commit而stash下来,现在全部没了,心慌的不行,几天的工作都白干了。于是到网上搜索了一下有没有可以抢救的方法。

方案

git stash 中的代码由于误操作而在其他分支执行了git stash pop 或者 git stash clear后代码丢失,抢救的方法大致有两个:

  1. 网上搜索到的比较多的就是执行
git fsck --lost-found 

执行完之后会得到很多 id ,其中会标明哪些是 commit,另一个blob不太清楚是什么东西

Checking object directories: 100% (256/256), done.
Checking objects: 100% (64354/64354), done.
dangling blob eb0a5cabe0d2030dbe0d203be0d224a8b9d46ef5
dangling blob 8b9d46ef59260ea17892401cb22e54f4df56bf04
dangling blob 5e13c8974187cdf3d8b9d46ef58bcb7ed88ce967
dangling blob a1140825d9cd8b9d46ef5b8d4f8685383kkd66a5
dangling blob 841a404f69eba49fb48b5d5ef18b9d46ef586468
dangling blob 36222c728e359
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你的git远程分支被误删除了,你可以按照以下步骤找回它: 1. 首先,使用命令`git reflog`来查询提交记录,这个命令可以打印被删除的commit或者分支commit记录。\[1\] 2. 在查询结果中找到对应被删除分支的最新commit信息记录。这个记录可以帮助你找回删除的分支。\[1\] 3. 接下来,使用命令`git checkout -b \[newBranch\] \[commitID\]`来创建一个新的分支,并将对应commit的数据记录拉取到新分支中。其中,`\[newBranch\]`是你想要创建的新分支的名称,`\[commitID\]`是你在第二步中找到的被删除分支的最新commit的ID。\[2\] 4. 完成以上步骤后,你就成功找回了被误删除git远程分支。记得在开发每个功能后及时进行commit,这样就能在log上产生记录树,以防止类似问题的发生。\[2\] 需要注意的是,如果在删除分支时本地有未commit的文件,那么无法恢复这些文件。因此,建议在开发过程中养成良好的习惯,及时commit,以防止这种情况的发生。\[3\] #### 引用[.reference_title] - *1* *2* *3* [Git---当本地分支和远程分支都被删除时,如何处理?](https://blog.csdn.net/COCOLI_BK/article/details/128130893)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值