用于计算两时间间隔的代码为什么运行不了
时间: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的啊
这是老罗书上的例子
.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 稍大点儿更合理些。
用 Sleep(10) 试验,数值差别很大,从 3 到 15 都有可能。Sleep(1000),即停留一秒,基本上都在 99x 了,也还不能精确到 1000 这个上面来。所以,Sleep() 函数,总有几个 Millisecond 的误差。其实,按道理来说,加上系统开销,这个值应该比 1000 稍大点儿更合理些。
作者: zara 发布时间: 2010-12-03
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28