Win32函数Sleep的精度测试
用了三种方法,第一种使用高精度性能计数器;第二种是使用多媒体定时器,另一种是《Windows图形编程》里提供的CPU周期来获取。推荐第一种方式测量:
先看第一种:
- #include <windows.h>
- #include <stdio.h>
- void main()
- {
- LARGE_INTEGER litmp;
- LONGLONG qt1,qt2;
- double dft,dff,dfm;
- //获得时钟频率
- QueryPerformanceFrequency(&litmp);//获得时钟频率
- dff=(double)litmp.QuadPart;
- //获得初始值
- QueryPerformanceCounter(&litmp);
- qt1=litmp.QuadPart;
- //下面一些耗时的操作
- Sleep(1);
- //获得终止值
- QueryPerformanceCounter(&litmp);
- qt2=litmp.QuadPart;
- //获得对应的时间值,转到毫秒单位上
- dfm=(double)(qt2-qt1);
- dft=dfm/dff;
- printf("用时: %.3f 毫秒\n", dft*1000.0);
- }
我的机器上为Sleep(1) = 0.454ms;Sleep(10) = 9.719ms;Sleep(100) = 99.541ms
下面是另外两种供参考:
- #include <stdio.h>
- #include <Windows.h>
- #include <Mmsystem.h>
- #include "timer.h"
- #pragma comment(lib, "winmm.lib")
- int i = 0;
- DWORD start;
- DWORD end;
- #define TIMES (1000)
- void main()
- {
- ////////////////////////////////////////////////////////////////////////////////
- //
- // 1. 使用高精度定时器初始化
- //
- //高精度定时器初始化
- // 注意: 如果不执行下面的初始化为1ms的语句,将影响Sleep()的精度
- ::timeBeginPeriod(1);
- Sleep(100);
- //开始计时
- start = ::timeGetTime();
- for (i=0; i<TIMES; i++)//累计测试
- {
- Sleep(1);
- }
- //结束计时
- end = ::timeGetTime();
- printf("使用高精度定时器测试Sleep(1)时间: %.3f ms\n", (end-start)/((double)TIMES));
- ////////////////////////////////////////////////////////////////////////////////
- //
- // 2. 使用CPU周期数方式获取
- //
- KTimer timer;
- //下面获取CPU的速度(MHz)
- timer.Start();
- Sleep(1000);
- unsigned __int64 cpuspeed = (unsigned)(timer.Stop()/1000000);
- printf("CPU速度: %I64d MHz\n", cpuspeed);
- //开始测试
- timer.Start();
- Sleep(1);
- //结束
- unsigned __int64 time = (unsigned) timer.Stop();
- printf("使用CPU周期数测得Sleep(1)时间: %I64d μs\n", time/cpuspeed);
- //
- // 测试完毕后,将定时精度调回来
- //
- ::timeEndPeriod(1);
- }
Win32函数Sleep的精度测试的更多相关文章
- C# 互操作性入门系列(二):使用平台调用调用Win32 函数
好文章搬用工模式启动ing ..... { 文章中已经包含了原文链接 就不再次粘贴了 言明 改文章是一个系列,但只收录了2篇,原因是 够用了 } --------------------------- ...
- [转]C# 互操作性入门系列(二):使用平台调用调用Win32 函数
传送门 C#互操作系列文章: C# 互操作性入门系列(一):C#中互操作性介绍 C# 互操作性入门系列(二):使用平台调用调用Win32 函数 C# 互操作性入门系列(三):平台调用中的数据封送处理 ...
- 关于 pgsql 数据库json几个函数用法的效率测试
关于 pgsql 数据库json几个函数用法的效率测试 关于pgsql 几个操作符的效率测试比较1. json::->> 和 ->> 测试方法:单次运行100次,运行10个单次 ...
- 在C#中调用Win32函数EnumWindows枚举所有窗口。
原文 http://www.cnblogs.com/mfm11111/archive/2009/06/30/1514322.html 开发旺旺群发软件,难点及重要技术点分析(一) 一. ...
- JavaScript回调函数及数组方法测试
JavaScript回调函数及数组方法测试 具体代码如下: <!DOCTYPE html> <html lang="en"> <head> &l ...
- elasticsearch 聚合函数 max double精度损失bug
测试样例数据{ "size" : 0, "query" : { "bool" : { "must" : { " ...
- PHP Socket 编程之9个主要函数的使用之测试案例
php的socket编程算是比较难以理解的东西吧,不过,我们只要理解socket几个函数之间的关系,以及它们所扮演的角色,那么理解起来应该不是很难了,在笔者看来,socket编程,其实就是建立一个网络 ...
- TRUNC函数,ORA-01898 精度说明符过多
TRUNC(SYSDATE)即可默认当前日期(年月日),TRUNC(SYSDATE,'yyyy-mm-dd'),精度说明符过多
- C# 中使用win32函数 GetScrollInfo返回false 返回引用全是零的问题
最近做一个项目要获得ScrollBar的位置,因为.net找不到此类功能,只好用MFC中的函数了,GetScrollPos只返回listview顶部的位置,此时我找到了GetScrollInfo,觉得 ...
随机推荐
- 注意 reader["yjID"] == DBNull.Value而不是null
自己做的项目吃的大亏,由于原始数据yjID这个字段里面什么都没有,所以,这个地方报错,说是字符串格式不支持,应该为DBNull.Value而不是null,DBNull.Value代表数据库(用的acc ...
- CentOS目录结构详解
CentOS是文件管理系统,在CentOS中所有的程序都以文件形式存储.初学CentOS的朋友需要了解各个挂载点 目录的结构和作用.这样才能更好的去管理系统. CentOS的目录大体上可分为四类:管理 ...
- JNI类型与C/C++映射关系
Java 类型 本地类型 描述 boolean jboolean C/C++8位整型 byte jbyte C/C++带符号的8位整型 char jchar C/C++无符号的16位整型 short ...
- Skin++ 皮肤库 CCheckListBox MFC 界面风格
今天使用CCheckListBox,发现增加进去的字符串无法显示,但是当点击的时候,确有反应. 仔细检查代码,没有问题.之前也是这样用的,完全没有问题. 思前想后,觉得是因为使用了Skin++皮肤库, ...
- java(try块语句变量,和匿名类变量生存时间
在try块定义的变量不能作用于快外 // int a=2; try{ int a=3; System.out.println(a); } catch(Exception e){} System.out ...
- [java] Java NIO 学习笔记 I
如今在运行时优化方面,JVM 已然前进了一大步.现在 JVM 运行字节码的速率已经接近本地 编译代码,借助动态运行时优化,其表现甚至还有所超越.这就意味着,多数 Java 应用程序已不 再受 CPU ...
- Foj1675数论
http://acm.fzu.edu.cn/problem.php?pid=1675 首先必须知道一点数论的基本公式 (a-b) %c =0 -----> a%c=b%c 首先通过大数取余求出目 ...
- CURL请求接口
private function http_curl($url,$data=null){ //1.初始化,创建一个新cURL资源 $ch = curl_init(); ...
- 在RichTextBox控件中添加图片和文字
public void SetText(RichTextBox rtb) { rtb.Text = "在RichTextBox控件中添加图片和文字" + Environment.N ...
- 按钮点击效果jquery
<html><head> <meta charset="UTF-8"> <title>QQ</title> <me ...