Period与Duration区别详解:Java时间处理核心差异
2026-02-22 20:27:55
0浏览
收藏
Java中Period与Duration虽同为时间差计算工具,却分属完全不同的语义维度:Period专精于日历日期的动态计算(如“几年几个月几天”,尊重闰年、月份天数等日历规则),而Duration专注精确时钟跨度(如“几小时几分钟几秒”,基于固定纳秒数,无视日历变化);二者类型不兼容、不可互换,误用轻则抛出DateTimeException,重则导致业务逻辑错误——选Period还是Duration,关键不在API怎么写,而在你问的问题本质:答案是否依赖日历?是,则用Period;否则,果断选Duration或ChronoUnit。

Period 和 Duration 看起来都算“时间差”,但它们根本不在一个维度上——前者管「日历日期」,后者管「精确时钟」;混用会直接抛 DateTimeException。
什么时候该用 Period?只和年/月/日打交道时
当你想回答“出生到现在过了几年几个月几天”“合同从2023-03-15到2025-11-20一共多少个月零几天”这类问题时,Period 是唯一合法选择。
Period.between()只接受两个LocalDate(不能是LocalDateTime或Instant)- 它内部按日历规则计算:比如 2024-01-31 到 2024-02-29 是 1 个月,不是 28 天
getDays()返回的是“剩余天数”,不是总天数;要总天数得用period.toTotalMonths()或手动转ChronoUnit.DAYS.between()- 错误示例:
Period.between(LocalDateTime.now(), LocalDateTime.of(2025,1,1,0,0))→ 抛异常
LocalDate start = LocalDate.of(1990, 5, 15); LocalDate end = LocalDate.of(2026, 1, 20); Period p = Period.between(start, end); System.out.println(p.getYears() + "年" + p.getMonths() + "月" + p.getDays() + "天"); // 输出:35年8月5天
什么时候该用 Duration?只要涉及时/分/秒/毫秒精度
当你需要知道“任务执行了多久”“API响应耗时多少纳秒”“两个时刻之间相隔几小时几分钟”时,必须用 Duration。
Duration.between()接受LocalTime、LocalDateTime、ZonedDateTime、Instant,但**不能传LocalDate**(会报错)- 它底层只算“总纳秒数”,不考虑闰年、夏令时、月份天数差异
- 输出格式是 ISO-8601 的
PT2H30M15.123S,不是人话;要用toHours()、toMinutes()等显式转换 - 注意:
Duration没有toDays()的精度保障——如果间隔不足 1 天,toDays()返回 0;要用toDaysPart()+toHoursPart()拆解
LocalDateTime start = LocalDateTime.of(2026, 1, 20, 2, 0, 0); LocalDateTime end = LocalDateTime.of(2026, 1, 20, 4, 30, 15); Duration d = Duration.between(start, end); System.out.println(d.toHours() + "小时" + d.toMinutesPart() + "分钟" + d.getSecondsPart() + "秒"); // 输出:2小时30分钟15秒
为什么不能互相替代?单位系统和语义完全不同
Period 是日历单位(calendar-based),Duration 是时钟单位(clock-based)——这决定了它们无法对齐。
- “1个月”在
Period中可能是 28、29、30 或 31 天;但在Duration中没有“月”这个概念,只有固定秒数(如Duration.ofDays(30)) Period.ofMonths(1)加到LocalDate.of(2024,1,31)得到2024-02-29(自动归约);而Duration.ofDays(30)加到同一天就是硬加 30 天 →2024-03-01- 跨时区场景下,
Duration依然可靠(因为基于Instant),而Period在时区转换中可能丢失语义(比如某地某月只有28天)
容易踩的坑:常见错误现象与修复方式
真实项目里,90% 的时间间隔 bug 都源于类型误用或单位混淆。
- 错误:用
Duration.between(LocalDate, LocalDate)→ 报UnsupportedTemporalTypeException;修复:改用ChronoUnit.DAYS.between(d1, d2)或先转成atStartOfDay() - 错误:把
Period当总天数用 →p.getDays()可能是 5,但实际跨度几百天;修复:明确需求,真要总天数就别用Period,改用ChronoUnit.DAYS.between() - 错误:用
Duration计算生日还剩几天 → 因为没考虑年份变化,结果永远是负数或不准;修复:生日是日期问题,必须用Period或LocalDate.until() - 错误:认为
Period.parse("P1M")和Duration.ofDays(30)等价 → 它们语义不同,不可互换,也不可比较大小
真正关键的不是记 API,而是每次写时间差逻辑前,先问自己一句:这个问题,答案是否依赖日历(比如“下个月今天”)?如果是,闭眼用 Period;否则,一律上 Duration 或 ChronoUnit。
今天关于《Period与Duration区别详解:Java时间处理核心差异》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
Win11关闭系统更新教程详解
- 上一篇
- Win11关闭系统更新教程详解
- 下一篇
- Windows10动态壁纸设置教程
查看更多
最新文章
-
- 文章 · java教程 | 38分钟前 |
- 抽象类有构造方法吗?父类初始化有何作用
- 361浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- 多实例下JPA批量更新安全同步方法
- 335浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- CopyOnWriteArrayList原理及使用详解
- 230浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- Hibernate异常处理与转换详解
- 314浏览 收藏
-
- 文章 · java教程 | 2小时前 |
- JavaIDE外工具配置全攻略
- 128浏览 收藏
-
- 文章 · java教程 | 2小时前 |
- Java中正确关闭finally资源的方法
- 171浏览 收藏
-
- 文章 · java教程 | 2小时前 |
- Eclipse创建JSP项目步骤详解
- 477浏览 收藏
-
- 文章 · java教程 | 2小时前 |
- 类与对象在Java中的含义解析
- 320浏览 收藏
-
- 文章 · java教程 | 2小时前 |
- JDKjhat工具:堆栈转储生成HTML报告
- 412浏览 收藏
-
- 文章 · java教程 | 3小时前 | 异步结果处理
- Java异步编程:CompletableFuture使用技巧
- 418浏览 收藏
-
- 文章 · java教程 | 3小时前 |
- Chocolatey安装Java教程详解
- 463浏览 收藏
-
- 文章 · java教程 | 3小时前 |
- Java序列化类映射安全实现方法
- 398浏览 收藏
查看更多
课程推荐
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
查看更多
AI推荐
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 4068次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 4413次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 4286次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 5652次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 4657次使用
查看更多
相关文章
-
- 提升Java功能开发效率的有力工具:微服务架构
- 2023-10-06 501浏览
-
- 掌握Java海康SDK二次开发的必备技巧
- 2023-10-01 501浏览
-
- 如何使用java实现桶排序算法
- 2023-10-03 501浏览
-
- Java开发实战经验:如何优化开发逻辑
- 2023-10-31 501浏览
-
- 如何使用Java中的Math.max()方法比较两个数的大小?
- 2023-11-18 501浏览

