首先定位到 工程目录\ .git\logs\refs\heads
这里会显示本地对应的分支名字(master
、 dev
等等)
然后找到你执行 reset
操作的分支名字, 比如 master
.
用 notepad++ 或者其他编辑器打开这个文件,内容结构如下:
0000000000000000000000000000000000000000 9e6a4411ffa8b857680d923916ae329795a27e39 username email 时间戳 时区 branch: Created from HEAD
9e6a4411ffa8b857680d923916ae329795a27e39 55b979d82534fa10c165a242a3d84ae1da54ab0b username email 时间戳 时区 commit: opt
55b979d82534fa10c165a242a3d84ae1da54ab0b c67cf7c3f40324a969d3162b51c8413e9be3b574 username email 时间戳 时区 merge master: Merge made by the 'recursive' strategy.
c67cf7c3f40324a969d3162b51c8413e9be3b574 a21d0c80d7092ee4d2067b90da202b8a5c5e8925 username email 时间戳 时区 reset: moving to a21d0c80d7092ee4d2067b90da202b8a5c5e8925
a21d0c80d7092ee4d2067b90da202b8a5c5e8925 a0da4025a0f67503d59f3b7b2f17efa16853aca4 username email 时间戳 时区 reset: moving to a0da4025a0f67503d59f3b7b2f17efa16853aca4
找到最下面最开始的一次 reset 操作,上面文件的倒数第二条。格式类似 a b username email 时间戳 时区 reset: moving to b
,就是从节点a reset
到了 节点b.
c67cf7c3f40324a969d3162b51c8413e9be3b574 a21d0c80d7092ee4d2067b90da202b8a5c5e8925 username email 时间戳 时区 reset: moving to a21d0c80d7092ee4d2067b90da202b8a5c5e8925
所以我们要恢复到a, 只是执行命令 git reset a, a是节点标识码 即 git reset c67cf7c3f40324a969d3162b51c8413e9be3b574
。