1 前言
本来是想把commit的存在缓存区的代码删除,再重新commit一遍的,用了git reset --hard HEAD^ 这个命令后,没想到本地代码退回到初始版本了,修改过的全部不见了。(悔不当初!)
2 解决办法
前提: git上传代码到仓库add、commit、push,代码必须是commit过的才有效,只有add不行。
2.1 步骤1
git fsck --lost-found
找到commit过的代码痕迹,dangling commit后面跟的就是代码。
2.2 步骤2
git show [dangling commit后面的字符串]
查看哪一个是自己删除的代码。
2.3 步骤3
git rebase [dangling commit后面的字符串]
恢复啦。
3 后记
这个方法必须是commit过的代码才行,如果只有add那还是恢复不了。所以,人生建议谨慎使用reset命令!
4 后记2.0
顺便来个正确的删除commit而不删除本地代码的方法:
git log
打印commit日志
git reset --soft [commit版本号]
回退到这个版本的commit
接着执行add、commit、push就行了
版权归原作者 雪小貂 所有, 如有侵权,请联系我们删除。