std::chrono::duration_cast是C++中用于在不同时间单位间显式转换的工具,定义于<chrono>头文件。它通过截断小数部分实现向下取整,适用于毫秒转秒、微秒转毫秒等场景,避免隐式转换导致的精度丢失或编译错误。例如将2500毫秒转为2秒,1234567微秒转为1234毫秒,常用于性能计时中时间间隔的单位转换。使用时需注意精度丢失不可逆,推荐在需要小数时采用浮点duration如std::chrono::duration<double>。

在C++中处理时间时,std::chrono::duration_cast 是一个非常实用的工具,用于在不同精度的时间单位之间进行转换。比如将毫秒转为秒、微秒转为毫秒等。它不会改变时间的实际值,而是重新解释其表示方式。
std::chrono::duration_cast 是一个模板函数,定义在 <chrono> 头文件中,用于在两个不同的 std::chrono::duration 类型之间进行显式转换。由于不同 duration 的精度可能不同(如纳秒、微秒、毫秒、秒),直接赋值可能会导致编译错误或精度丢失,因此需要用 duration_cast 显式转换。
它的基本语法是:
std::chrono::duration_cast<TargetDuration>(source_duration)
其中 TargetDuration 是你希望转换成的目标时间单位类型。
立即学习“C++免费学习笔记(深入)”;
以下是一些常见的使用场景和代码示例:
1. 毫秒转秒(向下取整)
#include <chrono>
#include <iostream>
<p>int main() {
auto milliseconds = std::chrono::milliseconds(2500);
auto seconds = std::chrono::duration_cast<std::chrono::seconds>(milliseconds);
std::cout << "2500 ms = " << seconds.count() << " s\n"; // 输出: 2 s
}注意:2500毫秒转为秒会截断小数部分,结果是2秒,不是2.5秒,因为 duration_cast 是向下取整(向零截断)。
2. 秒转毫秒
auto seconds = std::chrono::seconds(3); auto ms = std::chrono::duration_cast<std::chrono::milliseconds>(seconds); std::cout << "3 s = " << ms.count() << " ms\n"; // 输出: 3000 ms
这种转换是精确的,不会有精度损失。
3. 高精度转低精度(微秒转毫秒)
auto microseconds = std::chrono::microseconds(1234567); auto ms = std::chrono::duration_cast<std::chrono::milliseconds>(microseconds); std::cout << "1234567 μs = " << ms.count() << " ms\n"; // 输出: 1234 ms
这里只保留整数毫秒,微秒部分被舍去。
4. 计算运行时间并转换单位
#include <chrono>
#include <thread>
<p>int main() {
auto start = std::chrono::high_resolution_clock::now();</p><pre class="brush:php;toolbar:false;"><pre class="brush:php;toolbar:false;">// 模拟一些工作
std::this_thread::sleep_for(std::chrono::milliseconds(1500));
auto end = std::chrono::high_resolution_clock::now();
auto elapsed = std::chrono::duration_cast<std::chrono::milliseconds>(end - start);
std::cout << "耗时: " << elapsed.count() << " 毫秒\n";}
这是性能测量中最常见的用法之一,获取两个时间点之间的差值,并转换为你关心的单位。
1. 精度丢失是不可逆的
如果你从高精度转到低精度(如毫秒转秒),小数部分会被截断,不能恢复。
2. 不要用 double duration 来避免截断?可以,但要小心
如果你想保留小数部分,可以使用浮点类型的 duration:
auto ms = std::chrono::milliseconds(2500); auto sec_f = std::chrono::duration<double>(ms); std::cout << sec_f.count() << " s\n"; // 输出: 2.5 s
这不会使用 duration_cast,而是构造一个新的浮点 duration,适合需要小数精度的场景。
3. 避免跨类型隐式转换
下面的写法是错的:
std::chrono::seconds s = std::chrono::milliseconds(1000); // 编译错误!
必须显式使用 duration_cast:
std::chrono::seconds s = std::chrono::duration_cast<std::chrono::seconds>(
std::chrono::milliseconds(1000));std::chrono::nanoseconds — 纳秒std::chrono::microseconds — 微秒std::chrono::milliseconds — 毫秒std::chrono::seconds — 秒std::chrono::minutes — 分钟std::chrono::hours — 小时它们都是 std::chrono::duration 的特化版本,底层基于整数或浮点数。
基本上就这些。掌握 duration_cast 能让你在处理时间间隔时更灵活、安全。关键是记住:跨单位转换要用它,尤其是从高精度转低精度时,明确知道会发生截断。
以上就是C++中的std::chrono::duration_cast怎么用_C++时间处理与duration_cast使用的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号