git reset --hard 不要用!!!
git reset --hard 强制返回到某一次commit前的代码!!
如果用了通过以下方法 有可能!!!会找回;
如果你没有commit你的本地修改(甚至于你都没有通过git add追踪过这些文件,当他们被删除,git reset --hard对于这些没有被commit过也没有git add过的修改来说就是具有毁灭性的,destructive!!);
如果你曾经通过git add命令追踪过这些文件,只是没有commit它们!用
git fsck --lost-found
这个命令有可能会找回;然后在本地项目文件.git/lost-found/other路径中找到它们;这里面包含了所有的没有被commit(指定到某次commit)的文件,可能还包括你每次git add的版本(version);
使用
git fsck --lost-found
这个命令,通过.git/lost-found/other这个路径,你可以恢复任何你git add过的文件!再通过
find .git/objects -type f | xargs ls -lt | sed 30q
这个命令,你就可以找到最近被你add到本地仓库的30个文件(这个里面的30参数可以更改成任意的数字,比如200,它只是代表你想找回的最近的多少次add过的文件);
如果你没有git add过的文件,被git reset --hard这个命令整过之后,就如你自己执行delete命令一样,再也尸骨难寻!!!!
使用
git fsck --lost-found
这个命令,会在命令行窗口里面见到了一大堆的ID号码;
git fsck --lost-found //找回git add过但是已经不存在文件中的内容;
找到.git/lost-found/other这个路径下的文件;
在任意的编程软件中打开,就能看到每个文件本质是什么了;
使用
git cat-file -p ID > a.md
(将ID所示的文件读取出来重定向保存到
a.md
文件内,ID是objects后面的一串东西,比如
295c03fb1190cb3bbd9e44857d989acff94bed7b
)