C++标准方法
方法一:
auto startTime = std::chrono::system_clock::now();
auto endTime = std::chrono::system_clock::now();
// 示例
std::cout << "time:" << std::chrono::duration_cast<std::chrono::microseconds>(endTime - startTime).count() << std::endl;
其中可支持的时间类型有以下几种:
std::chrono::hours // 时
std::chrono::minutes // 分
std::chrono::seconds // 秒
std::chrono::milliseconds // 毫秒
std::chrono::microseconds // 微妙
std::chrono::nanoseconds // 纳秒
Linux平台
方法一:
clock_gettime
介绍说明
函数"clock_gettime"是基于Linux C语言的时间函数,他可以用于计算精度和纳秒
函数介绍
#include <ctime>
int clock_gettime(clockid_t clk_id, struct timespec *tp);
参数
clk_id : 检索和设置的clk_id指定的时钟时间。
CLOCK_REALTIME:系统实时时间,随系统实时时间改变而改变,即从UTC1970-1-1 0:0:0开始计时,中间时刻如果系统时间被用户改成其他,则对应的时间相应改变
CLOCK_MONOTONIC:从系统启动这一刻起开始计时,不受系统时间被用户改变的影响
CLOCK_PROCESS_CPUTIME_ID:本进程到当前代码系统CPU花费的时间
CLOCK_THREAD_CPUTIME_ID:本线程到当前代码系统CPU花费的时间
struct timespec
{
time_t tv_sec; /* 秒*/
long tv_nsec; /* 纳秒*/
};
备注:返回值含义未知 -- 以上参考百度百科
调用
// 计时示例
timespec startTime;
timespec endTime;
clock_gettime(CLOCK_REALTIME, &startTime);
clock_gettime(CLOCK_REALTIME, &endTime);
std::cout << "耗时:" << endTime.tv_sec - startTime.tv_sec << " 秒" << std::endl;