0

0

Java常用时间处理类库与LocalDate

P粉602998670

P粉602998670

发布时间:2026-01-05 18:35:02

|

225人浏览过

|

来源于php中文网

原创

localdate 是 java 8 引入的不可变日期类,仅表示“年-月-日”,替代易错、线程不安全的 date 和繁琐的 calendar;构造直观(月份 1–12)、线程安全、无时区歧义、支持 jdbc 4.2+ 直接映射。

java常用时间处理类库与localdate

LocalDate 是什么,为什么不用 Date 或 Calendar

LocalDate 是 Java 8 引入的 java.time 包中的不可变日期类,只表示“年-月-日”,不含时分秒和时区。它替代了过去容易出错、线程不安全的 Date 和操作繁琐的 Calendar

常见错误现象:用 new Date(2023, 1, 1)(月份从 0 开始)或 calendar.set(2023, 12, 1)(月份传 12 实际是下一年 1 月)导致日期偏移;SimpleDateFormat 非线程安全,在多线程中解析出错。

  • LocalDate 构造直观:LocalDate.of(2023, 1, 1),月份 1–12,无歧义
  • 所有方法返回新对象,天然线程安全
  • 不隐含时区或时间信息,避免“本地时间 vs UTC”混淆
  • 与数据库交互时,JDBC 4.2+ 支持直接映射 LocalDate 到 SQL DATE 类型

LocalDate 常用操作与易错点

日常开发中,LocalDate 主要用于计算天数差、加减月份、校验范围、格式化输出等。但几个参数和行为容易踩坑:

  • plusDays() / minusMonths() 等方法返回新实例,原对象不变 —— 忘记赋值是高频 Bug
  • withYear(2025) 会保留原有月日,但如果原日期是 2024-02-29,调用后抛 DateTimeException2025 年没有 2 月 29 日)
  • isBefore() / isAfter() 比较的是日期本身,不涉及时间或时区;但若混用 LocalDateTimeZonedDateTime,需先统一类型再比较
  • 解析字符串时,LocalDate.parse("2023/01/01", DateTimeFormatter.ofPattern("yyyy/MM/dd")) 必须显式传格式器,否则默认只认 "2023-01-01"
LocalDate today = LocalDate.now();
LocalDate nextWeek = today.plusDays(7); // ✅ 正确
today.plusDays(7); // ❌ 丢弃结果,today 不变
LocalDate invalid = LocalDate.of(2024, 2, 29).withYear(2025); // 抛异常

LocalDate 与旧 API 的互操作

老项目难免要和 DateCalendarjava.sql.Date 打交道。转换必须经过时区上下文,不能直接“强转”:

成新网络商城购物系统
成新网络商城购物系统

使用模板与程序分离的方式构建,依靠专门设计的数据库操作类实现数据库存取,具有专有错误处理模块,通过 Email 实时报告数据库错误,除具有满足购物需要的全部功能外,成新商城购物系统还对购物系统体系做了丰富的扩展,全新设计的搜索功能,自定义成新商城购物系统代码功能代码已经全面优化,杜绝SQL注入漏洞前台测试用户名:admin密码:admin888后台管理员名:admin密码:admin888

下载

立即学习Java免费学习笔记(深入)”;

  • LocalDatejava.util.Date:先转 atStartOfDay(ZoneId.systemDefault())ZonedDateTime,再转 Instant,最后到 Date
  • DateLocalDate:先用 date.toInstant().atZone(ZoneId.systemDefault()).toLocalDate() —— 注意时区影响结果(例如在东八区,new Date(0) 转成 LocalDate 是 1970-01-01,但在西五区可能是 1969-12-31)
  • java.sql.Date 可直接调用 .toLocalDate() 方法(JDBC 4.2+),比走 java.util.Date 更简洁安全
java.sql.Date sqlDate = java.sql.Date.valueOf("2023-05-20");
LocalDate localDate = sqlDate.toLocalDate(); // ✅ 推荐

Date utilDate = new Date();
LocalDate fromUtil = utilDate.toInstant()
    .atZone(ZoneId.systemDefault())
    .toLocalDate(); // ⚠️ 依赖系统默认时区

序列化与 JSON 处理注意事项

Spring Boot 默认用 Jackson 序列化 LocalDate,但行为取决于配置:

  • 未配置时,默认输出为数组格式:[2023,5,20]前端解析麻烦且不直观
  • @JsonFormat(pattern = "yyyy-MM-dd") 可控输出字符串,但需每个字段加注解,维护成本高
  • 全局配置推荐在 application.yml 中设:spring.jackson.date-format=yyyy-MM-ddspring.jackson.serialization.write-dates-as-timestamps=false
  • MyBatis 等 ORM 框架通常能自动处理 LocalDate 与数据库 DATE 字段映射,无需额外 TypeHandler(除非用老版本)

真正容易被忽略的是时区隐含假设:所有 LocalDate 序列化/反序列化都默认基于系统时区做“起点对齐”,一旦服务部署在不同时区机器上,且代码里又用了 LocalDateTime.now() 之类,可能引发数据错位。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1090

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

339

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

380

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2008

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

379

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1560

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

438

2024.04.29

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

4

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.1万人学习

C# 教程
C# 教程

共94课时 | 10.6万人学习

Java 教程
Java 教程

共578课时 | 76.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号