用了三种方法,第一种使用高精度性能计数器;第二种是使用多媒体定时器,另一种是《Windows图形编程》里提供的CPU周期来获取。推荐第一种方式测量:

先看第一种:

  1. #include <windows.h>
  2. #include <stdio.h>
  3. void main()
  4. {
  5. LARGE_INTEGER litmp;
  6. LONGLONG qt1,qt2;
  7. double dft,dff,dfm;
  8. //获得时钟频率
  9. QueryPerformanceFrequency(&litmp);//获得时钟频率
  10. dff=(double)litmp.QuadPart;
  11. //获得初始值
  12. QueryPerformanceCounter(&litmp);
  13. qt1=litmp.QuadPart;
  14. //下面一些耗时的操作
  15. Sleep(1);
  16. //获得终止值
  17. QueryPerformanceCounter(&litmp);
  18. qt2=litmp.QuadPart;
  19. //获得对应的时间值,转到毫秒单位上
  20. dfm=(double)(qt2-qt1);
  21. dft=dfm/dff;
  22. printf("用时: %.3f 毫秒\n", dft*1000.0);
  23. }

我的机器上为Sleep(1) = 0.454ms;Sleep(10) = 9.719ms;Sleep(100) = 99.541ms

下面是另外两种供参考:

  1. #include <stdio.h>
  2. #include <Windows.h>
  3. #include <Mmsystem.h>
  4. #include "timer.h"
  5. #pragma comment(lib, "winmm.lib")
  6. int i = 0;
  7. DWORD start;
  8. DWORD end;
  9. #define  TIMES  (1000)
  10. void main()
  11. {
  12. ////////////////////////////////////////////////////////////////////////////////
  13. //
  14. // 1.   使用高精度定时器初始化
  15. //
  16. //高精度定时器初始化
  17. //  注意: 如果不执行下面的初始化为1ms的语句,将影响Sleep()的精度
  18. ::timeBeginPeriod(1);
  19. Sleep(100);
  20. //开始计时
  21. start = ::timeGetTime();
  22. for (i=0; i<TIMES; i++)//累计测试
  23. {
  24. Sleep(1);
  25. }
  26. //结束计时
  27. end = ::timeGetTime();
  28. printf("使用高精度定时器测试Sleep(1)时间: %.3f ms\n", (end-start)/((double)TIMES));
  29. ////////////////////////////////////////////////////////////////////////////////
  30. //
  31. // 2. 使用CPU周期数方式获取
  32. //
  33. KTimer timer;
  34. //下面获取CPU的速度(MHz)
  35. timer.Start();
  36. Sleep(1000);
  37. unsigned __int64 cpuspeed = (unsigned)(timer.Stop()/1000000);
  38. printf("CPU速度: %I64d MHz\n", cpuspeed);
  39. //开始测试
  40. timer.Start();
  41. Sleep(1);
  42. //结束
  43. unsigned __int64 time = (unsigned) timer.Stop();
  44. printf("使用CPU周期数测得Sleep(1)时间: %I64d μs\n", time/cpuspeed);
  45. //
  46. // 测试完毕后,将定时精度调回来
  47. //
  48. ::timeEndPeriod(1);
  49. }

Win32函数Sleep的精度测试的更多相关文章

  1. C# 互操作性入门系列(二):使用平台调用调用Win32 函数

    好文章搬用工模式启动ing ..... { 文章中已经包含了原文链接 就不再次粘贴了 言明 改文章是一个系列,但只收录了2篇,原因是 够用了 } --------------------------- ...

  2. [转]C# 互操作性入门系列(二):使用平台调用调用Win32 函数

    传送门 C#互操作系列文章: C# 互操作性入门系列(一):C#中互操作性介绍 C# 互操作性入门系列(二):使用平台调用调用Win32 函数 C# 互操作性入门系列(三):平台调用中的数据封送处理 ...

  3. 关于 pgsql 数据库json几个函数用法的效率测试

    关于 pgsql 数据库json几个函数用法的效率测试 关于pgsql 几个操作符的效率测试比较1. json::->> 和 ->> 测试方法:单次运行100次,运行10个单次 ...

  4. 在C#中调用Win32函数EnumWindows枚举所有窗口。

    原文 http://www.cnblogs.com/mfm11111/archive/2009/06/30/1514322.html 开发旺旺群发软件,难点及重要技术点分析(一) 一.        ...

  5. JavaScript回调函数及数组方法测试

    JavaScript回调函数及数组方法测试 具体代码如下: <!DOCTYPE html> <html lang="en"> <head> &l ...

  6. elasticsearch 聚合函数 max double精度损失bug

    测试样例数据{ "size" : 0, "query" : { "bool" : { "must" : { " ...

  7. PHP Socket 编程之9个主要函数的使用之测试案例

    php的socket编程算是比较难以理解的东西吧,不过,我们只要理解socket几个函数之间的关系,以及它们所扮演的角色,那么理解起来应该不是很难了,在笔者看来,socket编程,其实就是建立一个网络 ...

  8. TRUNC函数,ORA-01898 精度说明符过多

    TRUNC(SYSDATE)即可默认当前日期(年月日),TRUNC(SYSDATE,'yyyy-mm-dd'),精度说明符过多

  9. C# 中使用win32函数 GetScrollInfo返回false 返回引用全是零的问题

    最近做一个项目要获得ScrollBar的位置,因为.net找不到此类功能,只好用MFC中的函数了,GetScrollPos只返回listview顶部的位置,此时我找到了GetScrollInfo,觉得 ...

随机推荐

  1. new关键字在虚方法的动态调用中的阻断作用

    关于new关键字在虚方法动态调用中的阻断作用,也有了更明确的理论基础.在子类方法中,如果标记 new 关键字,则意味着隐藏基类实现,其实就是创建了与父类同名的另一个方法,在编译中这两个方法处于动态方法 ...

  2. Design Pattern ——Builder

    一.基础知识:先前学习建造者模式的时候,总是以这个UML图作为学习基础资料 然后总是要记住四个角色 产品类:一般是一个较为复杂的对象,也就是说创建对象的过程比较复杂,一般会有比较多的代码量.在本类图中 ...

  3. 图文教程:手把手教你用U盘安装Ubuntu

    说到ubuntu,有接触linux的童鞋都应该听过,用wubi安装只是像在电脑上安装一个软件,可以轻松体验ubuntu,不过毕竟性能会打折扣,所以本人是比较喜欢直接安装在硬盘上的. 这种方法只适合用d ...

  4. MySQL 列子查询及 IN、ANY、SOME 和 ALL 操作符的使用

    列子查询是指子查询返回的结果集是 N 行一列,该结果通常来自对表的某个字段查询返回. 一个列子查询的例子如下: SELECT * FROM article WHERE uid IN(SELECT ui ...

  5. php中iconv函数的一个小bug--转载

    iconv转换字符集很好用,但是有时候你会发现iconv转换的时候会返回false或者空字符串,严格说来这算不上是iconv的问题,这其实是字符集的问题,但是实际编码中应该算是iconv的bug了. ...

  6. [转]javascript函数定义表达式和函数声明的区别

    在javascript中,函数有两种定义写法,函数定义表达式和函数声明,其例子分别如下所示: var test = function(x){ return x; } function test(x){ ...

  7. 使用2to3转换python代码

    如果要把python2编译器下的代码转换升级到python3编译器,可以使用python自带的 2to3工具进行转化: windows下转化: doc 命令窗口: >> python  C ...

  8. rsync指令详解

    rsync指令详解(更详细的看官方文档http://rsync.samba.org/ftp/rsync/rsync.html) [root@Centos epel]# rsync --help rsy ...

  9. phpcms V9 修改生成静态文件路径/html

    在论坛看到部分用户反馈这个问题,要修改的其实是html_root的值,默认是"/html"如果要生成在网站根目录的话,这个值则要为空.论坛上现在看到的办法是打开caches\con ...

  10. C#实现打印与打印预览功能(转)

    在windows应用程序中文档的打印是一项非常重要的功能,在以前一直是一个非常复杂的工作,Microsoft .Net Framework的打印功能都以组件的方式提供,为程序员提供了很大的方便,但是这 ...