C#怎么计算两个日期的差值_C#如何处理时间跨度【笔记】

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 工程
vue.js·python
杨云龙UP24 分钟前
Oracle RAC / ODA 生产环境指定 PDB 启动 SOP
linux·运维·数据库·oracle
kingwebo'sZone35 分钟前
在Cent上安装Mysql 8.0的遇到的问题和解决办法
数据库·mysql·adb
幽络源小助理44 分钟前
最新知识付费系统网站源码 PC+H5双端 附安装教程 – 幽络源源码网
大数据·数据库
小白考证进阶中1 小时前
Oracle OCP证书报考&考试全指南
数据库·oracle·oracle ocp·ocp认证·oracle认证·甲骨文认证·oracle ocp题库
星恒随风1 小时前
Python 基础语法详解(一):从表达式、变量到数据类型
开发语言·笔记·python·学习
888CC++1 小时前
java 并发编程
java·开发语言·python
Dxy12393102161 小时前
python缩放图片如何保证图片质量
python
Leon-Ning Liu2 小时前
【真实经验分享】 ORA-600 [qesmaGetTblSeg1]
数据库·oracle
与数据交流的路上2 小时前
MySQL 优化 -- 相关
数据库·mysql