C 语言

关注公众号 jb51net

关闭
首页 > 软件编程 > C 语言 > C++ chrono使用

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

作者: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();

转换为C风格时间

auto t = std::chrono::system_clock::to_time_t(now);

提取毫秒部分

auto ms = std::chrono::duration_cast<std::chrono::milliseconds>(
             now.time_since_epoch()
          ) % 1000;

格式化输出

oss << std::put_time(std::localtime(&t), "%F %T") 
    << "." << std::setw(3) << std::setfill('0') << ms.count();

最终输出格式
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使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文