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

2016-11-29 19:19:53来源:CSDN作者:qianhen123人点击

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


最新文章

123

最新摄影

微信扫一扫

第七城市微信公众平台