天天看点

git reset --hard 不要用!!!

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

)