C/C++测量时间的几种方式

时间:2022-09-09 19:52:35

1.计时5种方式

  共有五种计算时间的方式分别如下:

        //需要包含 “<Windows.h>”
	LARGE_INTEGER    a, a_, nFrequency;
	double timeAccuracy = 1000;
	QueryPerformanceFrequency(&nFrequency);
	QueryPerformanceCounter(&a);
	Sleep(period);
	QueryPerformanceCounter(&a_);   
	printf("%.8f\n", timeAccuracy * ((double)a_.QuadPart - a.QuadPart) / nFrequency.QuadPart);

	double b = GetTickCount();
	Sleep(period);
	double c = GetTickCount();
	printf("%.8f\n", (c-b));

	//需要包含"opencv2/core.hpp"
	double d = cvGetTickCount();
	Sleep(period);
	double e = cvGetTickCount();
	printf("%.8f\n", (e - d) / cvGetTickFrequency()/1000);

	//需要包含"<time.h>"
	long f = clock();
	Sleep(period);
	long g = clock();
	printf("%.8f\n", ((double)g - f) / CLOCKS_PER_SEC*1000);


	//需要包含"<chrono>,<numeric>,<iostream>"
	auto h = std::chrono::system_clock::now();
	Sleep(period);
	auto i = std::chrono::system_clock::now();
	std::chrono::duration<double> diff = i - h;
	printf("%.8f\n", diff.count()*1000);
以上输出均为毫秒.

2.计时精确度测量

上述输出全部为毫秒,在win7 sp1和64位机器,VS2013,release下。

当period设定为1,当10次循环求平均,输出为:

0.91895976
1.60000000
1.60000000
1.00481249
1.00000000

当period设定为1,当25次循环求平均,输出为:

0.98673408
0.64000000
0.64000000
0.99715482
1.00000000

当period设定为1,当50次循环求平均,输出为:

0.99323125
0.94000000
0.94000000
0.99962580
1.00000000

从稳定性和精确性的角度来说:

方式5>方式4>方式1>方式3>方式2


3.建议计时方式

在C中,优先使用方式4,其次是方式1

在C++中,优先使用方式5,其次是4和1,不精确计量情况下,可以调用opencv,即使用方式3