有关程序计时方法的介绍.pptVIP

  1. 1、本文档共21页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
有关程序计时方法的介绍 Yeung 讨论范围 计算机中的时间相关服务(函数)的主要应用 计时 延时 延时的主要内容和计时差不多,但和统计一个程序需要运行的时间不太相关,所以不做介绍 背景 计算机是怎么获得时间的? 时间是由谁提供的? 有哪些途径可以访问到与时间相关的服务? 方式一、获取系统内部时间 time_t time( time_t *timer ); From CRT library time.h time 返回自1970年1月1日午夜(UTC),到现在为止所经过的秒数。 参数timer提供一个存储时间的地址指针,可以为NULL,表示无需存储。 精度:1s 方式一、获取系统内部时间 time使用: #include stdio.h #include time.h int main() { time_t start = time(0); dosomething(); printf(“Used Time = %d s\n”, time(0) - start); return 0; } 方式一、获取系统内部时间 clock_t clock( void ); From CRT library time.h clock返回当前进程运行时间,时间单位 由CLOCKS_PER_SEC决定。 CLOCKS_PER_SEC表示1秒clock会增加的单位时间。 精度:1/CLOCKS_PER_SEC 注意:通常达不到 方式一、获取系统内部时间 clock使用: #include stdio.h #include time.h int main() { clock_t start = clock(); dosomething(); printf(“Used Time = %.2lf s\n”, (clock() – start) / CLOCKS_PER_SEC); return 0; } 方式一、获取系统内部时间 以上提供的两个函数都来自CRT Library。 下面介绍WINAPI中有关的计时API 方式一、获取系统内部时间 DWORD GetTickCount(void); Header: Declared in Winbase.h; include Windows.h. Library: Use Kernel32.lib. GetTickCount返回由系统开机到现在所经历的时间,单位毫秒。 精度:1ms 注意:实际达不到 方式一、获取系统内部时间 DWORD timeGetTime(VOID); 来自多媒体计时器 Header: Windows.h Library: Winmm.lib 方式二、高性能计时器(CPU时间戳) BOOL?QueryPerformanceFrequency (LARGE_INTEGER?*lpFrequency ); BOOL?QueryPerformanceCounter (LARGE_INTEGER?*lpPerformanceCount ); Header: Windows.h Library: Kernel32.lib 来自CPU内部的时间戳,也可以通过RDTSC指令获取时间戳 方式二、高性能计时器(CPU时间戳) LARGE_INTEGER 说白了就是一个64位无符号整数(unsigned __int64) 为什么要定义这个数据结构,目的是为了向C向下兼容 方式二、高性能计时器(CPU时间戳) 使用方法: int main() { __int64 Frequency, Start, End; QueryPerformanceFrequency((LARGE_INTEGER*)Frequency); QueryPerformanceCounter((LARGE_INTEGER*)Start); dosomething(); QueryPerformanceCounter((LARGE_INTEGER*)End); double t = double(End - Start) / Frequency; printf(Used Time = %.2lf s\n, t); } 方式二、高性能计时器(CPU时间戳) 缺点: 前两种方式只适合计时使用,并不能很好统计程序运行了多久 方式三、获取进程CPU时间 BOOL GetProcessTimes( HANDLE hProcess, LPFILETIME lpCreationTime, LPFILETIME lpExitTime, LPFILETIME lpKernelTime, LPFILETIME lpUserTime ); Header

文档评论(0)

海川电子书城 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档