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 reflog1
2HEAD@{0}: HEAD~1: updating HEAD
63ee781 HEAD@{1}: commit: test3:q
test3就是commit信息,然后拿到63ee781
可以运行git reset –hard 63ee781,则恢复了cmmit3,
运行 git log 后可以看到:1
2
3commit3: 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