C++(23): C++:STL中的时间库(std::chrono)

1. 简述

        C++ STL库中的 chrono 是一个关于日期和时间的库,它提供了一套丰富、灵活且类型安全的API,用于测量和操作时间。chrono 库是C++11标准的一部分,它使得我们可以进行高精度的时间测量,以及执行基于时间点的算术操作。

2. chrono的主要组件

(1)时间点(Time Points)

        表示一个特定的时间点,例如“2023-07-06 12:00:00”。chrono 库提供了几种时间点类型,如 system_clock::time_point,steady_clock::time_point,high_resolution_clock::time_point 等。

(2)时间长度(Durations)

        表示一段时间,例如“5小时”,“10分钟”或“2.5秒”。chrono 库提供了多种表示时间长度的类型,例如 hours,minutes,seconds,milliseconds,microseconds 和 nanoseconds。

(3)时钟(Clocks)

        用于获取当前时间点。chrono 库中定义了几个时钟类型,包括 system_clock(表示从1970年1月1日开始的实时时钟),steady_clock(表示一个不会被调整的时钟,通常用于测量持续时间),high_resolution_clock(提供最高精度的时钟)等。

3. 定义时间点并获得时间

        std::chrono::time_point是一个模板类,可以通过该类定义基于不同时钟的时间点。

        如下,定义了一个基于system_clock的时间点。

std::chrono::time_point<std::chrono::system_clock> sys_time_tic;

        之后可以通过如下方式获得某一时间点。

sys_time_tic = std::chrono::system_clock::now();

        也可以定义一个steady_clock或high_resolution_clock的时间点,分别如下所示。

std::chrono::time_point<std::chrono::steady_clock> steady_time_tic;

std::chrono::time_point<std::chrono::high_resolution_clock> high_res_time_tic;

        获取时间点的方式也有所不同,需要依赖于各自的时钟类型。

steady_time_tic = std::chrono::steady_clock::now();

high_res_time_tic = std::chrono::high_resolution_clock::now();

4. 定义一个时间长度

        一般情况下,我们使用std::chrono::duration来定义一个时间长度。

        其原型如下所示。

template<class Rep, class Period = std::ratio<1>>  

class duration;

Rep是一个数值类型,用来表示此持续时间的长度。这可以是任何数值类型,但通常是整数类型(如 int64_t、long long 等)或浮点数类型(如 double、float)。这个类型决定了能够表示的时间精度和范围。

Period是一个表示时间单位的类型,它通常是 std::ratio 的一个特化,用来表示时间的分母和分子。例如,std::ratio<1> 表示以秒为单位,std::ratio<1, 1000> 表示以毫秒为单位。这个模板参数使得 duration 可以灵活地表示不同的时间单位。

std::chrono::duration还有很多变种,可以更方便的表示一段时间。

  1. std::chrono::hours
  2. std::chrono::minutes
  3. std::chrono::seconds
  4. std::chrono::milliseconds
  5. std::chrono::microseconds
  6. std::chrono::nanoseconds

        举例来说,std::chrono::milliseconds类似于std::chrono::duration(int64_t, std::ratio(1, 1000)),但不完全等同,因为前者是一个特化类型,还包含了额外的一些特性。

5. 计算一个时间周期

        假如我们想计算一个操作的执行时间,我们定义两个时间点,分别是sys_time_tic和sys_time_toc,那么我们就可以通过std::chrono::duration或std::chrono::duration_cast计算这一操作所花费的时间。

如下,通过std::chrono::duration计算操作所需的秒数。

std::chrono::duration<double> elapsed = sys_time_tic - sys_time_toc;

当然也可以直接的进行转换,下面两种方式是一样的。

std::chrono::milliseconds duration = std::chrono::duration_cast<std::chrono::milliseconds>(end - start); 

auto duration = std::chrono::duration_cast<std::chrono::milliseconds>(end - start);  

通过count()获取实际的时长。

std::cout << "The operation took " << duration.count() << " milliseconds." << std::endl;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/13258.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JVM中的垃圾回收器是如何工作的?

JVM&#xff08;Java Virtual Machine&#xff09;中的垃圾回收器负责自动管理内存&#xff0c;它通过识别并释放不再被程序使用的对象来回收堆内存。以下是垃圾回收器的基本工作原理&#xff1a; 标记-清除&#xff08;Mark-Sweep&#xff09;算法&#xff1a; 初始时&#x…

美港通正规炒股市场沪指收跌0.82% 证券板块调整

5月15日电 15日,A股三大指数集体下挫。上证指数跌0.82%,报3119.9点;深证成指跌0.88%,报9583.54点;创业板指跌0.9%,报1838.89点。沪深京三市成交额7651亿元,其中沪深两市7611亿元,较上日缩量635亿元。沪深两市超3800只个股下跌。 美港通证券以其专业的服务和较低的管理费用在市…

数字集成电路物理设计[陈春章]——知识总结与精炼02

第二章 物理设计建库与验证 2.1 集成电路工艺与版图 自行了解&#xff0c;关于闩锁效应可查阅小编之前的文章。 2.2 设计规则检查&#xff08;DRC&#xff09; 定义&#xff1a;晶圆代工厂对各自不同工艺参数制定出满足芯片制造良率的同一工艺层及不同工艺层之间几何尺寸的…

ROS学习笔记(15)小车巡墙驾驶

0.前提 前一章我讲解了拉氏变换和PID&#xff0c;这一章我来讲解一下小车巡墙驾驶的理论和部分代码。 1.前情回顾 1.拉氏变换 拉普拉斯变换是要将时域问题转换成频域问题来处理。 2.PID控制器 转向角&#xff1a; 误差牺牲&#xff1a; 3.具体参看上一篇文章 2.巡墙驾驶…

「AIGC算法」图搜索算法详解

本文主要介绍图搜索算法详解和简单实例 一、原理 图搜索算法是一组用于在图结构数据上执行搜索任务的算法。图由顶点&#xff08;或称为节点&#xff09;和边组成&#xff0c;广泛应用于表示各种关系&#xff0c;如网络、路径、社交关系等。图搜索算法可以分为两大类&#xff…

【半监督学习】半监督学习中的时间集合

在本文中&#xff0c;我们提出了一种在半监督环境下训练深度神经网络的简单而高效的方法&#xff0c;在这种环境下&#xff0c;只有一小部分训练数据是有标签的。我们引入了self-ensembling技术&#xff0c;即利用网络在不同历时&#xff0c;最重要的是在不同正则化和输入增强条…

充电桩战火重燃,特来电、星星充电上演“龙虎斗”

配图来自Canva可画 小米Su7真的太火了&#xff0c;上市40天锁单量超过10万供不应求&#xff0c;给新能源汽车行业带来了新的活力&#xff0c;也促进了充电桩行业的发展。 据中国汽车工业协会数据&#xff0c;4月份新能源汽车产销分别完成87万辆和85万辆&#xff0c;同比分别增…

[LeetCode #202] 快乐数

目录 题目描述&#xff1a; 解题思路&#xff1a; 解题代码: 题目描述&#xff1a; 编写一个算法来判断一个数 n 是不是快乐数。 「快乐数」 定义为&#xff1a; 对于一个正整数&#xff0c;每一次将该数替换为它每个位置上的数字的平方和。然后重复这个过程直到这个数变…

地表最强ChatGPT爆了!我来告诉你,它都有什么用

OpenAI刚刚发布了全新的 "GPT-4o"&#xff0c;它不仅可以通过语音、视觉和文本进行推理&#xff0c;还在速度和价格上有了巨大的突破。它的速度提高了2倍&#xff0c;价格却降低了50%&#xff0c;而且生成速率比GPT-4 Turbo高出5倍。最令人惊喜的是&#xff0c;它将对…

【prometheus】prometheus基于consul服务发现实现监控

目录 一、consul服务发现简介 1.1 consul简介 二、prometheus配置 2.1 node-exporter服务注册到consul 2.2 修改prometheus配置文件 【Prometheus】概念和工作原理介绍_prometheus工作原理-CSDN博客 【Prometheus】k8s集群部署node-exporter 【prometheus】k8s集群部署p…

Python全栈自动化测试-Python基础07--分支结构if

目录 前言 一、单项分支 二、双向分支 三、多向分支 四、巢状分支&#xff08;嵌套分支&#xff09; 五、if中的判断条件 1.条件--固定值 2.条件--运算符 总结 前言 在Python编程中&#xff0c;分支结构是一种至关重要的控制流机制&#xff0c;它允许程序根据特定条件…

[前端] 深度选择器deep使用介绍(笔记)

参考文献 深度选择器 深度选择器deep使用说明 在 Vue 中&#xff0c;为了实现组件内部样式对组件外部元素的穿透覆盖&#xff0c;可以使用 CSS 的 deep 选择器&#xff08;也称为 >>> 或 /deep/&#xff09;或 v-deep 指令。然而&#xff0c;这两个方法在 Vue 3 中…

C语言之旅:动态内存管理

目录 一.为什么要有动态内存分配 二.malloc和free 2.1 malloc 2.2 free 2. 3malloc和free的使用 三. calloc 四. raelloc 4.1 代码示例&#xff1a; 4.2 注意事项&#xff1a; 4.3 对动态开辟空间的越界访问 4.4 对非动态开辟内存使⽤free释放 4.5 使用free释放⼀块…

在Python中防止某些字段被Pickle序列化

在Python中&#xff0c;如果你想防止某些字段被pickle序列化&#xff0c;可以使用__reduce__()方法来自定义pickle行为。__reduce__()方法允许你返回一个元组&#xff0c;其中包含要在对象被pickle时调用的函数以及传递给该函数的参数。下面就是我遇到的问题以及最终解决方案。…

2D Chests Assets - Mega Pack

科幻/奇幻/经典主题的箱子和容器。AAA质量,高分辨率,VFX,源PSD文件。 这是一个带有手绘套装的大包装: -【梦幻之栗】 -【科幻钱包】 AAA质量。高分辨率。一切都已准备就绪,可供使用。包括PSD文件。 在1.1版本中添加了VFX并将项目更新为URP。请注意,新的VFX仅适用于URP/HD…

C# WinForm —— 20 RichTextBox 介绍

1. 简介 富文本框&#xff0c;拥有TextBox的所有功能&#xff0c;&#xff0c;但还有更多高级的文本输入和编辑功能&#xff0c;比如设置字体颜色、样式、段落、图片、超链接等 2. 常用属性 属性解释(Name)控件ID&#xff0c;在代码里引用的时候会用到,一般以 rtxt 开头Acce…

Python中的数据可视化:填充等高线图matplotlib.pyplot.contourf()

【小白从小学Python、C、Java】 【考研初试复试毕业设计】 【Python基础AI数据分析】 Python中的数据可视化&#xff1a; 填充等高线图 matplotlib.pyplot.contourf() [太阳]选择题 关于代码描述正确的是&#xff1f; import matplotlib.pyplot as plt import numpy as np x …

java数据结构与算法(二叉树前序遍历)

前言 二叉树的前序遍历是一种特定的遍历方法&#xff0c;按照根节点、左子树、右子树的顺序进行遍历。和中序遍历和后续遍历类似&#xff0c;只是先将遍历到的根节点先做输出。 实现原理 前序遍历的具体过程如下&#xff1a; 前序遍历是一种用于二叉树的遍历方式&#xff0…

【奈学科技】P7大前端架构师1期

课程概述 一门专为有志于成为大前端架构师人群量身打造的课程。课程内容深度剖析大前端架构各环节核心架构&#xff08;组件化架构、微内核架构、微前端架构、前后端分离架构&#xff09;并对其进行排列组合形成大前端全局架构观以及培养架构师必备的架构思维模型。史无前例的…

基于若依的ruoyi-vue3.8.7的flowable支持指定接收人的流程审批前端部分

更多ruoyi-nbcio功能请看演示系统 gitee源代码地址 前后端代码&#xff1a; https://gitee.com/nbacheng/ruoyi-nbcio 演示地址&#xff1a;RuoYi-Nbcio后台管理系统 http://218.75.87.38:9666/ 更多nbcio-boot功能请看演示系统 gitee源代码地址 后端代码&#xff1a; h…