【C++ Boost库】原始计时器

文章目录

  • 前言
  • 一、原始计时器
    • 1.1 timer定时器
      • timer类的介绍
      • 异常安全
      • 代码概况
    • 1.2 progress_timer类
      • 如何使用
      • 异常安全
      • 代码概况
    • 1.3 progress_display类
      • 如何使用
      • 代码概况
  • 总结


前言

在现代软件开发中,时间是一种不可逆转的资源。特别是在需要按时执行任务、调度事件或者处理时间敏感的应用程序中,时间管理变得至关重要。在 C++ 编程中,使用合适的工具和库来管理时间是至关重要的。Boost C++ 库提供了一个强大的定时器库,使得时间管理变得简单而灵活。

本文将探索 Boost 定时器库的用法、特性以及它如何帮助 C++ 程序员处理时间相关的任务。我们将深入了解 Boost 定时器库的核心功能,并展示如何使用它来实现各种时间相关的应用程序。


一、原始计时器

1.1 timer定时器

timer类的介绍

这个计时器就像是一个简易的砂漏,用来测量经过的时间。它适合用于一些小型的计时任务。但是,它的实现依赖于C标准库中的clock()函数,这就像是在未知的沙漏中流动的沙子一样,我们不清楚它的准确度和精度。所以,这个计时器能够测量的最长时间可能只有596.5小时(甚至更少)。由于这些限制,这个计时器并不能保证其稳定性,如果稳定性是一个考虑因素,就不应该使用它。

异常安全

构造函数可能会抛出 .没有其他成员 函数引发异常。std::bad_alloc

代码概况

#include <boost/timer.hpp>
namespace boost {
class timer {public:timer();                        // postcondition: elapsed()==0// compiler generated copy constructor, copy assignment, and dtor applyvoid   restart();                      // post: elapsed()==0double elapsed() const;                // return elapsed time in secondsdouble elapsed_max() const;  // return estimated maximum value for elapsed()// Portability warning: elapsed_max() may return too high a value on systems// where std::clock_t overflows or resets at surprising values.double elapsed_min() const;            // return minimum value for elapsed()}; // timer
} // namespace boost

在这里插入图片描述

timer(): 默认构造函数,创建一个计时器对象,初始时计时为0。
restart(): 重置计时器,使其重新开始计时,将已经经过的时间置为0。
elapsed() const: 返回自计时器创建或上次重置以来经过的时间,以秒为单位。
elapsed_max() const: 返回估计的计时器能够测量到的最大时间值。需要注意的是,在某些系统上,std::clock_t 的溢出或重置可能会导致该函数返回意外的值。
elapsed_min() const: 返回计时器能够测量到的最小时间值。

1.2 progress_timer类

如何使用

这个“进度计时器”就像是一个神奇的魔法时钟,它会自动测量时间的流逝,并在适当的时机以适当的方式显示经过的时间消息,就像是在合适的地方挂着一面时光之镜一样。它的默认实现是在std::cout上显示字符。

“进度计时器”经常用于计算程序执行的时间。它的使用就像是轻轻一挥,一切都变得简单明了:

#include <boost/progress.hpp>
int main()
{progress_timer t;  // start timing// do something ...Sleep(100);return 0;
}

在这里插入图片描述

异常安全

构造函数可能会抛出 .没有其他成员 函数引发异常。std::bad_alloc

代码概况

#include <boost/progress.hpp>
namespace boost {
class progress_timer : public timer, noncopyable  {public:progress_timer();progress_timer( std::ostream& os ); // os is hint; implementation may ignore~progress_timer();}; // progress_display
} // namespace boost

在这里插入图片描述

1.3 progress_display类

如何使用

progress_display 类就像是一个可视化的指南针,它能够在适当的时机以适当的形式展示程序在达到预定目标时的进展情况。它满足了人们对程序是否在顺利进行的需求。

int main()
{progress_display show_progress(100);for (int i = 0; i < 100; i++){++show_progress;Sleep(10);}return 0;
}

在这里插入图片描述

他的参数为进度的count
如果你想使进度条向下进行,你可以使用前置++或者+=来实现

代码概况

#include <boost/progress.hpp>
namespace boost {
class progress_display : noncopyable {public:progress_display( unsigned long expected_count );// Effects: restart(expected_count)progress_display( unsigned long expected_count,std::ostream& os,  // os is hint; implementation may ignoreconst std::string & s1 = "\n", //leading stringsconst std::string & s2 = "",const std::string & s3 = "" )// Effects: save copy of leading strings, restart(expected_count)void           restart( unsigned long expected_count );//  Effects: display appropriate scale on three lines,//  prefaced by stored copy of s1, s2, s3, respectively, from constructor//  Postconditions: count()==0, expected_count()==expected_countunsigned long  operator+=( unsigned long increment )//  Effects: Display appropriate progress tic if needed.//  Postconditions: count()== original count() + increment//  Returns: count().unsigned long  operator++()//  Returns: operator+=( 1 ).unsigned long  count() const//  Returns: The internal count.unsigned long  expected_count() const//  Returns: The expected_count from the constructor.}; // progress_display
} // namespace boost

在这里插入图片描述


总结

Boost 定时器库为 C++ 开发者提供了一种强大而灵活的方式来处理时间相关的任务。通过使用 Boost 定时器库,开发者可以轻松创建、调度和管理定时任务,而无需过多的编码工作。本文介绍了 Boost 定时器库的重要性,并提供了一个简要的概述,希望读者能够进一步探索并利用 Boost 定时器库来加速他们的 C++ 开发工作。

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

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

相关文章

鸿蒙开发月薪过万,背后的秘密~

自从智联招聘公布出春节后首周的岗位需求数据后&#xff0c;鸿蒙开发岗位就被推上了热潮&#xff01;鸿蒙相关职位数同比增长163%&#xff0c;投递人数同比增长349%&#xff0c;即分别增至去年同期的2.6倍、4.5倍&#xff0c;涨势突出。 于是我的朋友圈中就有人去市场中简单探…

mybatisplus使用基本步骤

1.设计实体类&#xff0c;给实体类加一些需要的注解 2.创建Service接口继承mybatisplus提供的 IService<实体类>接口 3.实现Service接口&#xff0c;并继承mybatisplus提供的 ServiceImpl<mapper接口&#xff0c;实体类>类 4.mapper接口继承mybatisplus提供的 B…

程序人生——Java中基本类型使用建议

目录 引出Java中基本类型使用建议建议21&#xff1a;用偶判断&#xff0c;不用奇判断建议22&#xff1a;用整数类型处理货币建议23&#xff1a;不要让类型默默转换建议24&#xff1a;边界、边界、还是边界建议25&#xff1a;不要让四舍五入亏了一方 建议26&#xff1a;提防包装…

数据结构——通讯录项目

1.通讯录的介绍 顺序表是通讯录的底层结构。 通讯录是将顺序表的类型替换成结构体类型来储存用户数据&#xff0c;通过运用顺序表结构来实现的。 用户数据结构&#xff1a; typedef struct PersonInfo {char name[12];char sex[10];int age;char tel[11];char addr[100]; }…

ai一键生成思维导图!这5款ai软件口碑爆棚!

从去年到现在&#xff0c;AI 人工智能经过一年多的发展普及&#xff0c;正逐渐被越来越多的人所接受和使用&#xff0c;它从最初的 AI 文本生成&#xff0c;逐步过渡到图片生成&#xff08;AI 绘画&#xff09;、思维导图 AI 生成&#xff08;AI 绘图&#xff09;、PPT 演示文稿…

【XMU学科实践二】豆瓣爬虫实践

文章目录 分析豆瓣阅读网站完整爬虫代码 叠甲&#xff1a;仅供学习。。 XMU的小朋友实在不会了可以参考我的思路&#xff0c;但还是建议自己敲一遍哈。 学科实践二还是挺有意思的&#xff01; 分析豆瓣阅读网站 豆瓣阅读出版页面 打开浏览器开发者工具&#xff0c;可以看到如下…

JDK默认的垃圾回收器是什么?

在不同版本的Java开发工具包&#xff08;JDK&#xff09;中&#xff0c;JDK默认的垃圾回收器可能会有所不同。然而&#xff0c;自从Java 9发布后&#xff0c;G1&#xff08;Garbage-First&#xff09;垃圾回收器成为了Java平台的默认垃圾回收器。在此之前&#xff0c;Java 8及之…

php apache 后台超时设置

最近在写一个thinkphp项目的时候&#xff0c;发现Ajax从后端请求数据时间比较长&#xff0c;大概需要45秒左右&#xff0c;但是一旦请求时间超过40s&#xff0c;页面就会超时500了&#xff0c;一开始以为是ajax请求时间不能太长&#xff0c;后来将Ajax请求改为同步且timeout设置…

Navicat操作MYSQL

Navicat操作MYSQL 数据表的操作-创建表数据表的操作-修改、删除表数据的操作数据类型与约束常用数据类型数据约束 数据库备份与还原数据库的备份数据表的还原 数据表的操作-创建表 数据表的操作-修改、删除表 数据的操作 数据类型与约束 常用数据类型 整型&#xff1a;int 有符…

JVM 类的加载篇

我们都知道一个类从加载到卸载一共分为七个过程 加载 - 链接(验证 - 准备 - 解析) - 初始化 - 使用 - 卸载 下文我们将详细解析这些过程 谁需要加载? 在Java中数据类型分为基本数据类型和引用数据类型,基本数据类型由虚拟机预定义,引用数据类型则需要类的加载 1.加载/装载(loa…

智慧城市大模型来啦!港大百度推出UrbanGPT

论文作者解读链接&#xff1a;https://blog.csdn.net/qq_42715656/article/details/136681839 项目链接&#xff1a;https://urban-gpt.github.io/ 代码链接&#xff1a;https://github.com/HKUDS/UrbanGPT 论文链接&#xff1a;https://arxiv.org/abs/2403.00813 研究实验室链…