六种c++计时器函数(秒级到微妙级)

本文详细介绍了C++中六种不同的计时器实现方式,包括使用clock(), GetTickCount(), getTickCount(), time(), QueryPerformanceCounter()以及C++11 chrono库的方法。每种方法都提供了详细的代码示例,展示了如何进行ms、us级别的计时。

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

以下所有代码都有使用Sleep()延时函数,需 #include <Windows.h>

1.使用clock(),ms级别计时器 :

        double start = clock();
	Sleep(1000);
	double end = clock();
	double last = start - end;
	cout << last << "ms" << endl;

使用时需要包含头文件<ctime>

2. 使用GetTickCount(),ms级别计时器 :

        double start = GetTickCount(); //计时器
	Sleep(2000);
	double end = GetTickCount();
        double last = start - end;
	cout << last << "ms" << endl;

使用时需包含<Window.h>

 

3.使用getTickCount(),ms级别计时器:

        double start = getTickCount();//开始时间
	Sleep(2000);
	double end = getTickCount();
	double last = (end - start) * 1000 / getTickFrequency();
	cout << last << "ms" << endl;

这是opencv 所带计时器,使用时需#include <opencv2/opencv.hpp>,前面那个GetTickCount()是win的API。

4.使用time(NULL),s级别计时器:

        double start, stop, durationTime;
	start = time(NULL);
	Sleep(2000);
	stop = time(NULL);
	durationTime = (double)difftime(stop, start);
	cout << "程序耗时:" << durationTime << " s" << endl;

需要包含<ctime> 

5.微秒级计时器QueryPerformance:

        LARGE_INTEGER cpuFreq;
	LARGE_INTEGER startTime;
	LARGE_INTEGER endTime;
	
	QueryPerformanceFrequency(&cpuFreq);
	QueryPerformanceCounter(&startTime);
	Sleep(1000);
	QueryPerformanceCounter(&endTime);
	double last = (((endTime.QuadPart - startTime.QuadPart) * 1000000) / cpuFreq.QuadPart);
	cout << last << " us" << endl;

需要包含<Windows.h> 

还可以将其封装为一个类:

class stop_watch
{
public:
	stop_watch()
		: elapsed_(0)
	{
		QueryPerformanceFrequency(&freq_);
	}
	~stop_watch() {}
public:
	void start()
	{
		QueryPerformanceCounter(&begin_time_);
	}
	void stop()
	{
		LARGE_INTEGER end_time;
		QueryPerformanceCounter(&end_time);
		elapsed_ += (end_time.QuadPart - begin_time_.QuadPart) * 1000000 / freq_.QuadPart;
	}
	void restart()
	{
		elapsed_ = 0;
		start();
	}
	//微秒
	double elapsed()
	{
		return static_cast<double>(elapsed_);
	}
	//毫秒
	double elapsed_ms()
	{
		return elapsed_ / 1000.0;
	}
	//秒
	double elapsed_second()
	{
		return elapsed_ / 1000000.0;
	}

private:
	LARGE_INTEGER freq_;
	LARGE_INTEGER begin_time_;
	long long elapsed_;
};

int main()
{
	stop_watch watch;
	watch.start();
	Sleep(2000);
	watch.stop();
	cout << watch.elapsed() << endl;
}

6.C++11 chrono库,微秒级别计时器

        auto start = steady_clock::now();

	Sleep(1000);

	auto end = steady_clock::now();

	auto last = duration_cast<microseconds>(end - start);

	cout <<  last.count() << "um";

需要包含头文件 #include <chrono>并且using namespace std::chrono;

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值