【C/C++】chrono简单使用场景

chrono使用场景举例

1 输出格式化字符串

示例代码

cpp 复制代码
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. 获取当前时间点
cpp 复制代码
auto now = std::chrono::system_clock::now();
  • system_clock::now(): 获取当前系统时间点(UTC时间)
  • 返回类型:std::chrono::system_clock::time_point

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

  1. 提取毫秒部分
cpp 复制代码
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. 格式化输出
cpp 复制代码
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不是线程安全的(使用静态缓冲区)。多线程环境下应改用:

    cpp 复制代码
    std::tm tm_buf;
    localtime_r(&t, &tm_buf);  // POSIX
    // 或
    localtime_s(&tm_buf, &t);  // Windows
  2. C++20替代方案

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

    cpp 复制代码
    auto now = std::chrono::system_clock::now();
    return std::format("{:%Y-%m-%d %H:%M:%S}", now);
  3. 精度控制

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

    cpp 复制代码
    // 微秒示例
    auto us = std::chrono::duration_cast<std::chrono::microseconds>(
                 now.time_since_epoch()
              ) % 1000000;
相关推荐
人衣aoa3 分钟前
Python编程基础(二)| 列表简介
开发语言·python
让我们一起加油好吗4 分钟前
【基础算法】高精度(加、减、乘、除)
c++·算法·高精度·洛谷
Forest_HAHA5 分钟前
<5>, Qt系统相关
开发语言·qt
鑫鑫向栄28 分钟前
[蓝桥杯]缩位求和
数据结构·c++·算法·职场和发展·蓝桥杯
stormsha32 分钟前
MCP架构全解析:从核心原理到企业级实践
服务器·c++·架构
10000hours32 分钟前
【存储基础】NUMA架构
java·开发语言·架构
梁下轻语的秋缘32 分钟前
每日c/c++题 备战蓝桥杯(P1204 [USACO1.2] 挤牛奶 Milking Cows)
c语言·c++·蓝桥杯
鑫鑫向栄35 分钟前
[蓝桥杯]外卖店优先级
数据结构·c++·算法·职场和发展·蓝桥杯
Zfox_1 小时前
【C++项目】:仿 muduo 库 One-Thread-One-Loop 式并发服务器
linux·服务器·c++·muduo库
weixin_493202631 小时前
R语言错误处理方法大全
开发语言·r语言