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

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


  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值