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

【time-rs】Duration 结构体详解

这是一个 Rust 时间库中的Duration结构体实现,提供高精度的时间跨度表示。

1. 主要特性

  • 纳秒级精度:由整秒和纳秒部分组成
  • 支持负值:与标准库的std::time::Duration不同,支持负时间间隔
  • 安全边界检查:使用RangedI32确保纳秒值在有效范围(-999,999,999 到 999,999,999)

2. 核心结构

pubstructDuration{seconds:i64,// 整秒数nanoseconds:Nanoseconds,// 纳秒部分(带范围检查)padding:Padding,// 用于编译器优化(niche value optimization)}

3. 时间单位常量

提供了常用时间单位的预定义常量:

// 基本单位pubconstNANOSECOND:Self=Self::nanoseconds(1);pubconstMICROSECOND:Self=Self::microseconds(1);pubconstMILLISECOND:Self=Self::milliseconds(1);pubconstSECOND:Self=Self::seconds(1);pubconstMINUTE:Self=Self::minutes(1);pubconstHOUR:Self=Self::hours(1);pubconstDAY:Self=Self::days(1);pubconstWEEK:Self=Self::weeks(1);// 特殊值pubconstZERO:Self=Self::seconds(0);pubconstMIN:Self=Self::new_ranged(i64::MIN,Nanoseconds::MIN);pubconstMAX:Self=Self::new_ranged(i64::MAX,Nanoseconds::MAX);

4. 构造函数

多种构造方式:

// 从秒和纳秒创建letd1=Duration::new(1,500_000_000);// 1.5秒// 从时间单位创建letd2=Duration::hours(2);// 2小时letd3=Duration::minutes(30);// 30分钟// 从浮点数创建letd4=Duration::seconds_f64(1.5);// 1.5秒letd5=Duration::seconds_f32(0.5);// 0.5秒// 从小单位创建letd6=Duration::milliseconds(1500);// 1500毫秒letd7=Duration::microseconds(500);// 500微秒letd8=Duration::nanoseconds(100);// 100纳秒

5. 查询方法

获取整数值

letduration=Duration::hours(2)+Duration::minutes(30);duration.whole_hours();// 2duration.whole_minutes();// 150duration.whole_seconds();// 9000duration.whole_days();// 0

获取小数部分

letduration=Duration::seconds(1)+Duration::milliseconds(500);duration.as_seconds_f64();// 1.5duration.as_seconds_f32();// 1.5duration.subsec_milliseconds();// 500duration.subsec_microseconds();// 500000duration.subsec_nanoseconds();// 500000000

6. 属性检查

letpos=Duration::seconds(5);letneg=Duration::seconds(-5);letzero=Duration::ZERO;pos.is_positive();// truepos.is_negative();// falsepos.is_zero();// falseneg.is_positive();// falseneg.is_negative();// trueneg.is_zero();// falsezero.is_zero();// true

7. 数学运算

加法

letd1=Duration::seconds(5);letd2=Duration::seconds(3);// 普通加法(可能panic)letsum=d1+d2;// 8秒// 检查溢出的加法letchecked=d1.checked_add(d2);// Some(8秒)// 饱和加法letsaturated=Duration::MAX.saturating_add(d2);// Duration::MAX

减法

letd1=Duration::seconds(5);letd2=Duration::seconds(3);letdiff=d1-d2;// 2秒letneg_diff=d2-d1;// -2秒letchecked=d1.checked_sub(d2);// Some(2秒)

乘除法

letd=Duration::seconds(10);letmultiplied=d*2;// 20秒letdivided=d/2;// 5秒letfloat_mul=d*1.5;// 15秒letfloat_div=d/2.5;// 4秒

取反

letd=Duration::seconds(5);letnegated=-d;// -5秒

8. 与标准库互操作

usestd::time::DurationasStdDuration;// 从标准库转换letstd_duration=StdDuration::from_secs(5);lettime_duration=Duration::try_from(std_duration).unwrap();// 转换为标准库(无符号)letunsigned=time_duration.unsigned_abs();// 与标准库比较assert_eq!(Duration::seconds(5),StdDuration::from_secs(5));assert!(Duration::seconds(10)>StdDuration::from_secs(5));

9. 格式化显示

letduration=Duration::hours(2)+Duration::minutes(30);// 完整格式println!("{}",duration);// "2h30m0s"// 简洁格式(带精度)println!("{:.2}",duration);// "2.50h"println!("{:.0}",duration);// "3h"

10. 设计亮点

  1. 范围安全性:使用RangedI32保证纳秒值始终有效
  2. 零成本抽象:编译时检查,运行时无额外开销
  3. 完备的数学运算:支持各种算术操作
  4. 良好的错误处理:提供 panic 和 Result 两种风格的 API
  5. 与标准库兼容:便于与现有代码集成

11. 性能优化

  • Niche Value Optimization:通过Padding字段优化内存布局
  • 内联函数:大多数方法标记为#[inline]
  • 常量求值:尽可能在编译时计算
  • 避免分支:使用位操作处理浮点数转换

12. 使用场景

  • 时间间隔计算:计算两个时间点之间的差值
  • 定时任务:设置延迟或周期性执行
  • 性能测量:测量代码执行时间
  • 时间运算:进行时间加减运算
  • 序列化/反序列化:作为时间数据的中间表示

这个实现特别适合需要处理相对时间、倒计时、时间差计算的场景,弥补了标准库Duration不支持负值的不足。

http://www.rkmt.cn/news/94837.html

相关文章:

  • Python基础知识的总结(2)
  • Go程序的执行顺序
  • JavaWeb-Request应用与Cookie[特殊字符]️Session
  • 数据结构:二叉排序树,平衡二叉树,红黑树的介绍
  • 基于条件风险价值CVaR的微网动态定价与调度策略附Matlab代码
  • Go语言变量
  • 架构系统序化
  • OpenVSCode Server终极性能调优与资源管理完整指南
  • ASP毕业设计题目推荐:基于ASP+Access的校园二手交易平台设计与实现
  • 【Arduino Uno】数码管模拟值实验
  • 进程PCB
  • Springboot医药采购管理2mqc3(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
  • LeetCode 41. 缺失的第一个正数 | 原地哈希最优解全解析
  • 线性回归模型
  • 榛子矮砧密植:水肥一体化系统的铺设要点指南
  • java基础流程控制笔记
  • 校招 Java 面试必看:JVM 其实就考这 3 个点(我帮你讲透)
  • [从零构建操作系统]08 函数调用时栈的底层行为解析
  • MATLAB与FlightGear联合仿真教程:包含Simulink工程文件的PDF指南
  • Springboot医疗云胶片管理系统nem7x(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
  • Day 37 MLP神经网络的训练
  • 探索含光伏、火电与飞轮储能系统的奇妙调频之旅
  • 高效获取高质量外链:2026年必须掌握的10个核心策略
  • Flutter国际化(i18n)实现详解
  • YOLOv13涨点改进 | 独家创新首发、Conv卷积改进篇 | SCI一区 2025 | 引入MSConvStar多尺度卷积星形模块,有效增强捕捉多范围特征,助力目标检测、图像分割、图像分类高效涨点
  • LLC谐振变换器恒压恒流双竞争闭环Simulink仿真探索
  • Feign基本知识
  • YOLOv13涨点改进 | 全网独家创新、Neck特征融合改进篇 | TGRS 2025顶刊 | 引入ADSF自适应特征融合模块,自适应融合浅层特征与深层特征,适合红外小目标检测、图像分割等有效涨点
  • 常用软件工具的使用(1) ---- git 的安装和基础操作
  • 双电机纯电动汽车整车仿真模型,基于Matlab/Simulink的双电机前后轴双驱电动汽车仿真模型