C/C++ chrono简单使用场景示例详解

 更新时间:2025年06月04日 10:32:36   作者:CodeWithMe  
这篇文章主要介绍了C/C++ chrono简单使用场景示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧

chrono使用场景举例

1 输出格式化字符串

示例代码

auto now = std::chrono::system_clock::now();
auto t = std::chrono::system_clock::to_time_t(now);
auto ms = std::chrono::duration_cast<std::chrono::milliseconds>(now.time_since_epoch()) % 1000;
std::ostringstream oss;
oss << std::put_time(std::localtime(&t), "%F %T")
    << "." << std::setw(3) << std::setfill('0') << ms.count();

这段代码使用C++11的<chrono>库获取当前时间并生成带毫秒的时间戳字符串。

获取当前时间点

auto now = std::chrono::system_clock::now();
  • system_clock::now(): 获取当前系统时间点(UTC时间)
  • 返回类型:std::chrono::system_clock::time_point

转换为C风格时间

auto t = std::chrono::system_clock::to_time_t(now);
  • to_time_t(): 将time_point转换为time_t(自1970-01-01起经过的秒数)
  • 用于后续调用传统C时间函数

提取毫秒部分

auto ms = std::chrono::duration_cast<std::chrono::milliseconds>(
             now.time_since_epoch()
          ) % 1000;
  • time_since_epoch(): 获取从时钟纪元到now的时间间隔
  • duration_cast<milliseconds>: 将时间间隔转换为毫秒精度
  • % 1000: 取模运算获取当前秒内的毫秒数(0-999)

格式化输出

oss << std::put_time(std::localtime(&t), "%F %T") 
    << "." << std::setw(3) << std::setfill('0') << ms.count();
  • localtime(&t): 将time_t转换为本地时间的tm结构
  • put_time(..., "%F %T"): 格式化为YYYY-MM-DD HH:MM:SS
  • %F 等价于 %Y-%m-%d
  • %T 等价于 %H:%M:%S
  • ms.count(): 获取毫秒数值(整数)
  • setw(3) + setfill('0'): 确保毫秒固定3位(如5→"005")

最终输出格式
YYYY-MM-DD HH:MM:SS.sss
示例:2023-10-05 14:30:45.123

注意事项

线程安全性
std::localtime不是线程安全的(使用静态缓冲区)。多线程环境下应改用:

std::tm tm_buf;
localtime_r(&t, &tm_buf);  // POSIX
// 或
localtime_s(&tm_buf, &t);  // Windows

C++20替代方案
C++20的<chrono>库提供更简洁的时间格式化:

auto now = std::chrono::system_clock::now();
return std::format("{:%Y-%m-%d %H:%M:%S}", now);

精度控制
当前代码精确到毫秒,如需微秒/纳秒:

// 微秒示例
auto us = std::chrono::duration_cast<std::chrono::microseconds>(
             now.time_since_epoch()
          ) % 1000000;

到此这篇关于C/C++ chrono简单使用场景示例详解的文章就介绍到这了,更多相关C++ chrono使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C++判断pe文件实例

    C++判断pe文件实例

    这篇文章主要介绍了C++判断pe文件的方法,包含了文件操作的具体实现方法,具有很好的参考借鉴价值,需要的朋友可以参考下
    2014-10-10
  • 深入理解C++模板如何实现多态思想

    深入理解C++模板如何实现多态思想

    这篇文章主要为大家详细介绍了C++模板如何实现多态的相关资料,文中的示例代码讲解详细,对我们深入了解C++有一定的帮助,感兴趣的可以了解一下
    2023-03-03
  • 详解C语言中的memset()函数

    详解C语言中的memset()函数

    这篇文章主要介绍了C语言中的memset()函数,包括其与memcpy()函数的区别,需要的朋友可以参考下
    2015-08-08
  • 数据结构课程设计-用栈实现表达式求值的方法详解

    数据结构课程设计-用栈实现表达式求值的方法详解

    本篇文章是对在c语言中用栈实现表达式求值的方法进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C语言入门学习之fgets()函数和fputs()函数

    C语言入门学习之fgets()函数和fputs()函数

    fgetc() 和 fputc() 函数每次只能读写一个字符,速度较慢,实际开发中往往是每次读写一个字符串或者一个数据块,这样能明显提高效率,这篇文章主要给大家介绍了关于C语言入门学习之fgets()函数和fputs()函数的相关资料,需要的朋友可以参考下
    2021-11-11
  • 关于C语言除0引发的思考

    关于C语言除0引发的思考

    很多 C 库都提供了一组函数用来判断一个浮点数是否是无穷大或 NaN。int _isnan(double x) 函数用来判断一个浮点数是否是 NaN,而 int _finite(double x) 用以判断一个浮点数是否是无穷大
    2013-08-08
  • C++索引越界的解决方法

    C++索引越界的解决方法

    本文主要介绍了C++索引越界的解决方法,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • 一篇文章教你在C++中操作符可分为哪几种类和用法

    一篇文章教你在C++中操作符可分为哪几种类和用法

    这篇文章主要介绍了C++编程中操作符的种类和用法,是C++入门学习中的基础知识,需要的朋友可以参考下,希望能够给你带来帮助
    2021-09-09
  • C语言实现商品管理系统开发

    C语言实现商品管理系统开发

    这篇文章主要为大家详细介绍了C语言实现商品管理系统开发,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • C++函数重载介绍与原理详解

    C++函数重载介绍与原理详解

    这篇文章主要为大家介绍了C++函数重载介绍与原理,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01

最新评论