/////////////////////////////////////////////////
#include <iostream>
#include <windows.h>
using namespace std;
////////////////////////////////////////////////
void main()
{
_LARGE_INTEGER time_start; /*开始时间*/
_LARGE_INTEGER time_over; /*结束时间*/
double dqFreq; /*计时器频率*/
LARGE_INTEGER f; /*计时器频率*/
QueryPerformanceFrequency(&f);
dqFreq=(double)f.QuadPart;
QueryPerformanceCounter(&time_start);
Sleep(1000);/*循环耗时*/
QueryPerformanceCounter(&time_over);
cout<<((time_over.QuadPart-time_start.QuadPart)/dqFreq)<<endl;//单位为秒,精度为1000 000/(cpu主频)微秒
}
#include <iostream>
#include <windows.h>
using namespace std;
////////////////////////////////////////////////
void main()
{
_LARGE_INTEGER time_start; /*开始时间*/
_LARGE_INTEGER time_over; /*结束时间*/
double dqFreq; /*计时器频率*/
LARGE_INTEGER f; /*计时器频率*/
QueryPerformanceFrequency(&f);
dqFreq=(double)f.QuadPart;
QueryPerformanceCounter(&time_start);
Sleep(1000);/*循环耗时*/
QueryPerformanceCounter(&time_over);
cout<<((time_over.QuadPart-time_start.QuadPart)/dqFreq)<<endl;//单位为秒,精度为1000 000/(cpu主频)微秒
}
本文介绍了一种使用 C++ 在 Windows 平台上精确测量 CPU 时间的方法。通过利用 Windows API 函数 QueryPerformanceCounter 和 QueryPerformanceFrequency 来获取高精度的时间戳,并演示了如何计算程序片段的执行时间。
2119

被折叠的 条评论
为什么被折叠?



