016F:004B05DE WAIT
016F:004B05DF FLD TWORD [EBP-12]
016F:004B05E2 FLD TWORD [004B0674]
016F:004B05E8 FMULP ST1
016F:004B05EA FLD TWORD [004B0680]
016F:004B05F0 FSUBP ST1
016F:004B05F2 FSTP TWORD [EBP-12]
016F:004B05F5 WAIT
016F:004B05F6 JMP SHORT 004B0612
016F:004B05F8 MOV EAX,[EBP-04]
016F:004B05FB CALL `VCL30!SysUtils.StrToInt@0F6FDFF6`
016F:004B0600 MOV [EBP-1C],EAX
我们在4B05DB处打开了浮点窗口(用wf命令)这条命令会将浮点栈ST0数字保存到了EBP-12处先记下浮点栈里显示数字然后F8单步到4B05DE我们先用d ebp-12看看看见堆相信我们中很多人记不住浮点格式吧就算记住了你会去计算它下吗?显然不会!那如何办?盲人摸象?不!我们来试试dt ebp-12看到什么了?就是刚才从浮点栈里保存去数字!这是如何回事?看看这段解释(摘自Softice4命令中文解说太平洋软件Software资讯站):
命令: D
作用: 显示某内存区域内容
语法: D[size] [address [l length]]
使用方法:
size: B 字节; W 字; D 双字; S 短实型; L 长实型;
T 10b长实型
D 命令在所指定内存区域开始显示指定长度内存
单元内容. 格式将根据size来变.对于双字类型, 将分
两种情况:
1.如果指定地址为32位段, 格式为32s16进制值(即8位16进制值)
2.如果指定地址为16位段, 则格式为16:16指针形式(即4:4位16进制值)
如果没有指定地址,D 命令将继上次命令后地址开始显示.如果数据窗口可见,则结果在数据窗口中显示,否则显示在命令窗口中.但若用了参数L 和长度, 则结果不论数据窗口可见还是不可见,都显示在命令窗口中.
最新评论