C++程序计时方法

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;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值