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

【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>库获取当前时间并生成带毫秒的时间戳字符串。

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

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

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

  1. 格式化输出
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


注意事项

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

    std::tm tm_buf;
    localtime_r(&t, &tm_buf);  // POSIX
    // 或
    localtime_s(&tm_buf, &t);  // Windows
    
  2. C++20替代方案
    C++20的<chrono>库提供更简洁的时间格式化:

    auto now = std::chrono::system_clock::now();
    return std::format("{:%Y-%m-%d %H:%M:%S}", now);
    
  3. 精度控制
    当前代码精确到毫秒,如需微秒/纳秒:

    // 微秒示例
    auto us = std::chrono::duration_cast<std::chrono::microseconds>(now.time_since_epoch()) % 1000000;
    
http://www.xdnf.cn/news/9777.html

相关文章:

  • 国密SSL证书有哪些技术优势?
  • 基于qt5和stk10开发的互联调试
  • 黑马程序员C++核心编程笔记--4 类和对象--封装
  • Unity中的JsonManager
  • C++双线程交替打印奇偶数(活泼版)
  • 2024 CKA模拟系统制作 | Step-By-Step | 15、查看Pod日志
  • 委托从入门到入土
  • Elasticsearch的集群管理介绍
  • 乾元通渠道商中标青海省自然灾害应急能力提升工程基层防灾项目
  • 充电便捷,新能源汽车移动充电服务如何预约充电
  • DAY 14 SHAP库的绘制
  • 2024 CKA模拟系统制作 | Step-By-Step | 12、创建多容器Pod
  • 系统安装出现的问题 老毛桃
  • 【C++】SDL2环境安装及AI编码简单的俄罗斯方块游戏
  • 阿里云服务器邮件发送失败(dail tcp xxxx:25: i/o timeout)因为阿里云默认禁用 25 端口
  • List 源码翻译
  • LeetCode 215:数组中的第K个最大元素 - 两种高效解法详解
  • npm run build 报错:Some chunks are larger than 500 KB after minification
  • 2-向量可视化
  • 【C++高级主题】命令空间(三):未命名的命名空间
  • IT选型指南:电信行业需要怎样的服务器?
  • springboot配置cors拦截器与cors解释
  • 代理IP在云计算中的应用:技术演进与场景实践
  • React 生命周期与 Hook:从原理到实战全解析
  • 车载通信网络 --- CAN FD与CAN XL
  • SQLite 中文写入失败问题总结
  • 无人设备遥控器之红外技术篇
  • Arbitrum Stylus 合约实战 :Rust 实现 ERC20
  • lua的注意事项2
  • 跟Gemini学做PPT-模板样式的下载