+ -
当前位置:首页 → 问答吧 → 用于计算两时间间隔的代码为什么运行不了

用于计算两时间间隔的代码为什么运行不了

时间:2010-12-02

来源:互联网

.386
.model flat,stdcall
option casemap:none
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
; Include 文件定义
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
include windows.inc
include user32.inc
includelib user32.lib
include kernel32.inc
includelib kernel32.lib
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
; 数据段
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>



.data
string1 db 1024 dup (?)
string2 db '%ld',0 
dwlm dd 1000000

.data?
dq1 dq ?
dq2 dq ?
dqfreq dq ?
dqtime dq ?


;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
; 代码段
;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
.code


start:

  invoke QueryPerformanceCounter,addr dq1
invoke Sleep,(10)

invoke QueryPerformanceCounter,addr dq2
invoke QueryPerformanceFrequency,addr dqfreq
mov eax,dword ptr dq1
mov edx,dword ptr dq1+4
sub dword ptr dq2,eax
sbb dword ptr dq2+4,edx

finit
fild dqfreq
fild dq2
fimul dwlm
fdivr
fistp dqtime

invoke wsprintf,addr string1,addr string2,dqtime
invoke MessageBox,NULL ,addr string1,addr string1,MB_OK


;invoke MessageBox,NULL,offset szText,offset szCaption,MB_OK
invoke ExitProcess,NULL;>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
end start


应该是输出10的啊
这是老罗书上的例子

作者: MSOKD   发布时间: 2010-12-02

应该是 Sleep() 对微小数值时间的延时不准确吧。另外,dwlm 定义我 1000000 不对吧,应该是 1000,因为 Sleep() 的时间单位是 Millisecond 毫秒。
用 Sleep(10) 试验,数值差别很大,从 3 到 15 都有可能。Sleep(1000),即停留一秒,基本上都在 99x 了,也还不能精确到 1000 这个上面来。所以,Sleep() 函数,总有几个 Millisecond 的误差。其实,按道理来说,加上系统开销,这个值应该比 1000 稍大点儿更合理些。

作者: zara   发布时间: 2010-12-03