git-reflog-in-order-to-recovery-deleted-files-or-be-rebased-commits

git reflog 可以查看所有分支的所有操作记录(包括(包括commit和reset的操作),包括已经被删除的commit记录
git log 则不能察看已经删除了的commit记录

具体一个例子,假设有三个commit:
commit3: add test3.c
commit2: add test2.c
commit1: add test1.c

如果执行 git reset –hard HEAD~1 则删除了commit3,如果发现删除错误了,需要恢复commit3,
或者是rebase的时候被rebase掉了,
这个时候就要使用 git reflog

1
2
HEAD@{0}: HEAD~1: updating HEAD
63ee781 HEAD@{1}: commit: test3:q

test3就是commit信息,然后拿到63ee781
可以运行git reset –hard 63ee781,则恢复了cmmit3,
运行 git log 后可以看到:

1
2
3
commit3: add test3.c
commit2: add test2.c
commit1: add test1.c

这里也可以使用另外一种方法来实现:

1
git cherry-pick 63ee78

感谢原作者 http://blog.csdn.net/ibingow/article/details/7541402
希望可帮到你,Best wishes