DateTime.Subtract() 直接返回 TimeSpan,应优先使用;注意 .Days 与 .TotalDays 区别:前者为整数天部分,后者为精确小数天;超时判断用 TotalHours 或 Duration();高精度测时用 Stopwatch;业务日期逻辑需用 NodaTime 等专用库。用 DateTime.Subtract() 得到 TimeSpan 是最直接的方式两个 DateTime 相减,C# 会自动返回 TimeSpan 对象,里面封装了天、小时、分钟等完整差值信息。这不是"计算技巧",而是语言内置行为,别绕路去手动拆年月日。常见错误是拿到 TimeSpan 后只读 .TotalDays 或 .Days,却没注意二者区别:.Days 是总天数取整(忽略小时分钟),.TotalDays 是带小数的精确天数(比如 1.5 表示 36 小时)。要判断是否超过 24 小时 → 用 ts.TotalHours > 24要显示"X 天 Y 小时" → 用 ts.Days 和 ts.Hours(注意:这两个是"剩余部分",不是累计)跨时区比较前,先统一转成 DateTimeKind.Utc,否则 Subtract() 可能因本地时区偏移出错TimeSpan 的 .Days 和 .TotalDays 容易混淆TimeSpan.Days 返回的是"天字段"的值,范围是 -999 到 +999,只代表差值中完整的天数部分;而 TimeSpan.TotalDays 是把整个时间跨度换算成天(含小数)。比如相差 36 小时,.Days == 1,.TotalDays == 1.5。典型误用场景:做超时判断时写 if (ts.Days >= 1),结果 23 小时 59 分钟也被放过------因为 .Days 还是 0。判断是否满 1 天 → 用 ts.TotalDays >= 1 或 ts >= TimeSpan.FromDays(1)格式化输出"3天12小时" → $"{ts.Days}天{ts.Hours}小时"(前提是 ts 非负且不超 int 范围)如果 ts 是负的(后一个时间更早),.Days 和 .Hours 也会是负数,但 .Duration() 可以取绝对值需要考虑日期精度时,避免直接用 DateTime.NowDateTime.Now 的分辨率通常只有 10--15 毫秒,连续两次调用可能返回相同值,导致 Subtract() 出现 0 差值。这不是 bug,是 Windows 系统计时器限制。 橙篇 百度文库发布的一款综合性AI创作工具
相关推荐
岁月宁静20 分钟前
驾驭 AI 这匹野马:深入解析智能体 Harness 工程杨云龙UP24 分钟前
Oracle RAC / ODA 生产环境指定 PDB 启动 SOPkingwebo'sZone35 分钟前
在Cent上安装Mysql 8.0的遇到的问题和解决办法幽络源小助理44 分钟前
最新知识付费系统网站源码 PC+H5双端 附安装教程 – 幽络源源码网小白考证进阶中1 小时前
Oracle OCP证书报考&考试全指南星恒随风1 小时前
Python 基础语法详解(一):从表达式、变量到数据类型888CC++1 小时前
java 并发编程Dxy12393102161 小时前
python缩放图片如何保证图片质量Leon-Ning Liu2 小时前
【真实经验分享】 ORA-600 [qesmaGetTblSeg1]与数据交流的路上2 小时前
MySQL 优化 -- 相关