当前位置: 首页 > news >正文

[转]windows性能计时器

LARGE_INTEGER
LARGE_INTEGER是union;用于表示一64位有符号整数值.其他定义如下:

View Code
typedef   union   _LARGE_INTEGER   {    
struct {
DWORD LowPart;
LONG HighPart;
};
LONGLONG QuadPart;
} LARGE_INTEGER;

如果你有编译器直接支持64位整数可以直接使用QuadPart(64位),否则分别对LowPart(32位)和HighPart(32位)存取,HighPart的最高位为符号位。
表示数的范围:--3689348814741910324到+4611686018427387903 
LARGE_INTEGER的值等4000000000,在内存中的布局: 
00   28   6B   EE       00   00   00   00        
   (低字节   )             (高字节   )   

QueryPerformanceFrequency()
类型:Win32API
原型:BOOL QueryPerformanceFrequency(LARGE_INTEGER *lpFrequency);
作用:返回硬件支持的高精度计数器的频率。
返回值:非零,硬件支持高精度计数器;零,硬件不支持,读取失败。
QueryPerformanceFrequency() - 技术特点供WIN9X使用的高精度定时器:QueryPerformanceFrequency()和QueryPerformanceCounter(),要求计算机从硬件上支持高精度定时器。
函数的原形是:
  BOOL QueryPerformanceFrequency(LARGE_INTEGER *lpFrequency);
  BOOL QueryPerformanceCounter (LARGE_INTEGER *lpCount);
数据类型LARGEINTEGER既可以是一个作为8字节长的整数,也可以是作为两个4字节长的整数的联合结构,其具体用法根据编译器是否支持64位而定。该类型的定义如下:

View Code
typeef union _ LARGE_INTEGER
  {
     struct
     {
       DWORD LowPart;
       LONG HighPart;
     };
     LONGLONG QuadPart;
} LARGE_INTEGER;

在定时前应该先调用QueryPerformanceFrequency()函数获得机器内部计时器的时钟频率。接着在需要严格计时的事件发生前和发生之后分别调用QueryPerformanceCounter(),利用两次获得的计数之差和时钟频率,就可以计算出事件经历的精确时间。测试函数SLEEP(100)的精确持续时间方法:

View Code
  LARGE_INTEGER litmp;
  LONGLONG qt1,qt2;
  double dft,dff,dfm;
  QueryPerformanceFrequency(&litmp);//获得时钟频率
  dff=(double)litmp.QuadPart;
  QueryPerformanceCounter(&litmp);//获得初始值
  qt1=litmp.QuadPart;Sleep(100);
  QueryPerformanceCounter(&litmp);//获得终止值
  qt2=litmp.QuadPart;
  dfm=(double)(qt2-qt1);
  dft=dfm/dff;//获得对应的时间值

需要注意的是DFT计算的结果单位是秒。

【参考资料 感谢作者】
http://www.cnblogs.com/whiteyun/archive/2009/09/17/1568240.html
http://www.cppblog.com/deane/articles/113151.html 

补充:上面所说的内容我的理解是只能用来做计时器,不能用来做定时器。(计时器和定时器有区别吧?)
另外我查阅到资料,有GetSystemTimeAsFileTime()和clock(),这两者都是获取现有时间来计时的,故不是很精准,和sleep一样的效果。请看下面

View Code
#include <stdio.h>
#include <Windows.h>
#include <time.h>

int main(int argc, char* argv[])
{
FILETIME beg,end;
GetSystemTimeAsFileTime(&beg);
Sleep(2000);
GetSystemTimeAsFileTime(&end);

clock_t cbeg,cend;
cbeg=clock();
Sleep(2000);
cend=clock();

LARGE_INTEGER start;
LARGE_INTEGER endt ;
LARGE_INTEGER frequency;
if (!QueryPerformanceFrequency(&frequency))
{
return -1;
}
QueryPerformanceCounter(&start);
Sleep(2000);
QueryPerformanceCounter(&endt);

printf("%d ns\n",100*(end.dwLowDateTime-beg.dwLowDateTime));
printf("%d ms\n",cend-cbeg);
printf("main cost:%f\n", (double)(endt.QuadPart - start.QuadPart) / (double)frequency.QuadPart);
return 0;
}

运行结果为:

LARGE_INTEGER在运行过程中的值:(请注意成员的值)

转载于:https://www.cnblogs.com/ziwuge/archive/2011/10/11/2207383.html

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • jquery实战---标签页效果
  • 前言
  • 在Android Studio中使用shareSDK进行社会化分享(图文教程)
  • 如何在LightSwitch中创建多栏自动完成的下拉框
  • erLang语言特性及游戏应用的可行性分析
  • MongoDB远程主从部署下的全量数据同步及故障恢复策略
  • .NET 4 并行(多核)“.NET研究”编程系列之二 从Task开始
  • Windows2003发布MVC4网站
  • 面试中如何介绍自己做过的运维项目
  • [nowCoder] 两个不等长数组求第K大数
  • Flex Cairngorm详解
  • 宽带接入
  • MongoDBTool - 测试版【GUI美化完毕】 源代码发布 --MongoDB爱好者,Winform爱好者 请进...
  • .net 流——流的类型体系简单介绍
  • 把Javascript放置到何处
  • 【5+】跨webview多页面 触发事件(二)
  • Angular js 常用指令ng-if、ng-class、ng-option、ng-value、ng-click是如何使用的?
  • EventListener原理
  • java B2B2C 源码多租户电子商城系统-Kafka基本使用介绍
  • Laravel 中的一个后期静态绑定
  • magento2项目上线注意事项
  • Mocha测试初探
  • mongo索引构建
  • Mybatis初体验
  • nginx(二):进阶配置介绍--rewrite用法,压缩,https虚拟主机等
  • OpenStack安装流程(juno版)- 添加网络服务(neutron)- controller节点
  • SpringCloud(第 039 篇)链接Mysql数据库,通过JpaRepository编写数据库访问
  • vue2.0一起在懵逼的海洋里越陷越深(四)
  • Webpack入门之遇到的那些坑,系列示例Demo
  • 阿里云ubuntu14.04 Nginx反向代理Nodejs
  • 笨办法学C 练习34:动态数组
  • 从重复到重用
  • 个人博客开发系列:评论功能之GitHub账号OAuth授权
  • 记一次删除Git记录中的大文件的过程
  • 前端自动化解决方案
  • 全栈开发——Linux
  • 设计模式 开闭原则
  • 思维导图—你不知道的JavaScript中卷
  • 推荐一款sublime text 3 支持JSX和es201x 代码格式化的插件
  • 微信小程序:实现悬浮返回和分享按钮
  • 微信小程序--------语音识别(前端自己也能玩)
  • 问题之ssh中Host key verification failed的解决
  • 一份游戏开发学习路线
  • raise 与 raise ... from 的区别
  • ​ArcGIS Pro 如何批量删除字段
  • ​卜东波研究员:高观点下的少儿计算思维
  • #if 1...#endif
  • #include到底该写在哪
  • ()、[]、{}、(())、[[]]等各种括号的使用
  • (175)FPGA门控时钟技术
  • (DenseNet)Densely Connected Convolutional Networks--Gao Huang
  • (el-Date-Picker)操作(不使用 ts):Element-plus 中 DatePicker 组件的使用及输出想要日期格式需求的解决过程
  • (ros//EnvironmentVariables)ros环境变量
  • (vue)el-tabs选中最后一项后更新数据后无法展开
  • (阿里巴巴 dubbo,有数据库,可执行 )dubbo zookeeper spring demo