C/C++中如何精确计时

本文介绍在Windows环境下使用C/C++进行精确计时的方法,通过使用`LARGE_INTEGER`、`QueryPerformanceFrequency`和`QueryPerformanceCounter`等函数实现毫秒级甚至更精确的时间测量,为程序员提供了一种替代Windows标准`clock()`函数的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


        给程序计时对于程序员来说实在是太重要了,在windows上的那个clock()实在是不够精确,精度只有10ms,真让人难过。研究了下windows下使用C、
C++ 计时的函数,给大家分享下。

  主要就是两个函数的使用。我先把一段可以运行的代码贴出来,然后讲讲这两个函数。

 

 #include <windows.h>
 #include <stdio.h>

int main(int argc, char **argv)

{

 LARGE_INTEGER freq;
 LARGE_INTEGER start_t, stop_t;
 double exe_time;
 QueryPerformanceFrequency(&freq);
 fprintf(stdout, "The frequency of your pc is %d.\n", freq.QuadPart);
 QueryPerformanceCounter(&start_t);
 Sleep(1000);
 QueryPerformanceCounter(&stop_t);   
 exe_time = 1e3*(stop_t.QuadPart-start_t.QuadPart)/freq.QuadPart;
 fprintf(stdout, "Your program executed time is %fms.\n", exe_time);
 getchar();
 return 0;
} 

 

1、LARGE_INTEGER在微软的编译器中实际上是一个union,它的定义如下:

 

 typedef union _LARGE_INTEGER
  {
       struct
       {
           DWORD LowPart;
           LONG HighPart;
       };
       struct
       {
           DWORD LowPart;
           LONG HighPart;
       } u;
       LONGLONG QuadPart;
   } LARGE_INTEGER,  *PLARGE_INTEGER;


如果你使用的编译器支持64位整数,那么可以使用QuadPart来引用变量的值。如果你的编译器不支持64位整数,那么可以使用LowPart和HighPart来引用64位整数的低32位和高32位。

  2、QueryPerformanceFrequncy(LARGE_INTEGER *freq)

  它用于获得你的机器一秒钟执行多少次,就是你的时钟周期。

  3、QueryPerformanceCounter(LARGE_INTEGER *lpPerformanceCount)

  它获得的是CPU从开机以来执行的时钟周期数。


运行界面如下:






 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值