当前位置: 首页 > news >正文

C++ 中的耗时计算函数

#include <time.h>int clock_gettime (clockid_t clock_id, struct timespec *tp) 

获取当前 clock_id 的时钟值并存储在 tp 中。

其中 tp 是一个 timespec 结构体,在 time.h 头文件中定义:

#include <time.h>:struct timespec {time_t   tv_sec;        /* seconds */long     tv_nsec;       /* nanoseconds */
};

clock_id 是识别系统时钟的 ID,常用的定义有以下几种:

  1. CLOCK_REALTIME:这是实际的时间,即从 1970 年 1 月 1 日(UTC)至今的秒数。这种计时方式会受到 NTP(网络时间协议)的影响,系统时间可能会被自动调整。用户可以修改系统时间,但修改后会影响到 CLOCK_REALTIME 的计数。
  2. CLOCK_MONOTONIC:这是单调时间,即从系统启动到现在的时间。CLOCK_MONOTONIC 时钟不受系统时间不连续跳跃的影响(例如,如果系统管理员手动更改时钟),但是受到由 adjtime() 和 NTP 执行的增量调整的影响。在系统休眠(suspend)时,CLOCK_MONOTONIC 会停止增加。
  3. CLOCK_MONOTONIC_RAW:与 CLOCK_MONOTONIC 类似,但不同之处在于它不会受到 NTP 的影响。即使 NTP 服务器和本地的时钟硬件之间存在问题,NTP 也不会影响到 CLOCK_MONOTONIC_RAW 的频率。该时钟 ID 从 Linux 2.6.28 内核开始引入,Linux 特有。
  4. CLOCK_BOOTTIME:与 CLOCK_MONOTONIC 类似,当系统进入休眠(suspend)时,它会继续增加。

可以通过「man 3 clock_gettime」命令查阅 Linux 手册获取 clock_id 更详细信息。

我们通过以下示例来展示程序运行耗时的计算方法:

#include <time.h>int main(int argc, char const *argv[])
{struct timespec start, end;clock_gettime(CLOCK_MONOTONIC_RAW, &start);func_or_code_here();    // your code ...clock_gettime(CLOCK_MONOTONIC_RAW, &end);long elapsed_ms = (end.tv_sec - start.tv_sec) * 1000 + (end.tv_nsec - start.tv_nsec) / 1e6;return 0;
}

在上面的示例中,通过 clock_gettime() 函数获取运行时刻的实际时间并存储在 startend 两个变量中,然后计算经过的时间(毫秒),最后得出函数运行耗时。

以下是一种 C++ 的封装方式,文件名为 timer.h,仅供参考:

#include <time.h>class Timer {
public:Timer() {reset();}~Timer() = default;long elapsed_sec() {clock_gettime(CLOCK_MONOTONIC_RAW, &_end);return (_end.tv_sec - _start.tv_sec) + (_end.tv_nsec - _start.tv_nsec) / 1e9;        }long elapsed_ms() {clock_gettime(CLOCK_MONOTONIC_RAW, &_end);return (_end.tv_sec - _start.tv_sec) * 1000 + (_end.tv_nsec - _start.tv_nsec) / 1e6;}long elapsed_us() {clock_gettime(CLOCK_MONOTONIC_RAW, &_end);return (_end.tv_sec - _start.tv_sec) * 1e6 + (_end.tv_nsec - _start.tv_nsec) / 1000;}long elapsed_ns() {clock_gettime(CLOCK_MONOTONIC_RAW, &_end);return (_end.tv_sec - _start.tv_sec) * 1e9 + (_end.tv_nsec - _start.tv_nsec);}void reset() {clock_gettime(CLOCK_MONOTONIC_RAW, &_start);}private:struct timespec _start;struct timespec _end;
};

在以上的封装过程中,在 Timer 类中定义了 _start_end 成员变量,用于存储开始时间与结束时间,Timer 类提供了计算耗时的秒(elapsed_sec),毫秒(elapsed_ms),微秒(elapsed_us),纳秒(elapsed_ns)的成员函数。同时提供了 reset 函数用于重新计时。在这里我们可以通过以下示例来更好地理解 Timer 的用法:

#include <iostream>
#include "timer.h"int main(int argc, char const *argv[])
{Timer t;func_or_code_here();    // your code ...long elapsed_ms = t.elapsed_ms();return 0;
}
http://www.lryc.cn/news/273896.html

相关文章:

  • 【Element】el-form和el-table嵌套实现表格编辑并提交表单校验
  • 初识Winform
  • Redis:原理速成+项目实战——Redis实战5(互斥锁、逻辑过期解决缓存击穿问题)
  • 前端优化之一:dns预获取 dns-prefetch 提升页面载入速度
  • C语言中一些基本数据类型的典型大小
  • [C/C++]排序算法 快速排序 (递归与非递归)
  • 『年度总结』逐梦编程之始:我的2023学习回顾与展望
  • MyBatis学习二:Mapper代理开发、配置文件完成增删改查、注解开发
  • 【React系列】受控非受控组件
  • OpenCV-Python(22):2D直方图
  • Kubernetes 100个常用命令
  • labuladong日常刷题-差分数组 | LeetCode 1109航班预定统计 | 花式遍历 151反转字符串里的单词
  • HbuilderX中的git的使用
  • LeetCode每日一题 | 1944. 队列中可以看到的人数
  • React16源码: JSX2JS及React.createElement源码实现
  • 整理composer安装版本的python脚本
  • 十、基本对话框大集合(Qt5 GUI系列)
  • 大A又跌了
  • This error originates from a subprocess, and is likely not a problem with pip
  • 数据库基础知识1
  • 【GO语言卵细胞级别教程】01.GO基础知识
  • 215.【2023年华为OD机试真题(C卷)】按身高和体重排排队(排序题-JavaPythonC++JS实现)
  • 虚函数(C++)
  • 力扣25题: K 个一组翻转链表
  • 网络安全应急响应工具之-流量安全取证NetworkMiner
  • http 401 错误
  • Docker-Compose部署Redis(v7.2)哨兵模式
  • 解决问题:PPT中插入视频编辑模式可以播放,幻灯片放映后播放不了
  • 使用react+vite开发项目时候,部署上线后刷新页面无法访问解决办法
  • 45. 跳跃游戏 II(Java)