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

Java 时间处理 API 全解析:从 JDK7 到 JDK8 的演进

个人主页-爱因斯晨

友友们,互三咯~

目录

个人主页-爱因斯晨

​编辑

前言

一、JDK7 时间处理基石 ——Date 类

(一)Date 类基本功能

(二)Date 类的局限性

二、格式化时间好帮手 ——SimpleDateFormat 类

(一)格式化与解析原理

(二)常用模式符号

(三)格式化操作示例

(四)解析操作示例

三、更灵活的时间操作工具 ——Calendar 类

(一)Calendar 类特点

(二)获取 Calendar 实例

(三)常用方法及示例

(四)与 Date 类相互转换

四、JDK8 时间类 —— 新时代的时间处理方案

(一)LocalDate、LocalTime、LocalDateTime

(二)ZoneId 与 ZonedDateTime—— 时区处理

(三)DateTimeFormatter—— 线程安全的格式化工具

五、JDK7 与 JDK8 时间类对比与选择

(一)对比

(二)选择建议

六、总结


 

前言

在 Java 开发领域,时间处理是一项极为常见且关键的需求。无论是记录用户的操作时间,还是实现定时任务等功能,都离不开对时间 API 的灵活运用。本文围绕 JDK7 与 JDK8 中的时间处理类,结合学习内容,详细梳理Date、SimpleDateFormat、Calendar以及 JDK8 全新时间类的使用与演进,助力开发者掌握 Java 时间处理的核心要点。

一、JDK7 时间处理基石 ——Date 类

(一)Date 类基本功能

Date类位于java.util包下,是 JDK7 中用于表示特定瞬间的时间类,其精度可达到毫秒级别。它的出现,为 Java 处理时间提供了基础能力。

创建Date对象的方式较为简单,通过无参构造方法可以直接获取当前系统时间:

import java.util.Date;
public class DateDemo {public static void main(String[] args) {Date now = new Date();System.out.println("当前系统时间:" + now); }
}

上述代码的输出结果类似Thu Jul 23 10:00:00 CST 2025,能够直观地呈现当下的时间信息。

(二)Date 类的局限性

尽管Date类能够获取和表示时间,但在实际开发过程中,它的短板逐渐显现出来:

  • 可读性差:直接输出的时间格式对于普通用户而言不够友好,难以快速理解其中包含的具体年月日时分秒信息。
  • 操作不便捷:如果想要获取年、月、日等单独的时间字段,需要结合其他类(如Calendar),无法直接从Date对象中简洁地提取,这无疑增加了时间处理的复杂度。

二、格式化时间好帮手 ——SimpleDateFormat 类

(一)格式化与解析原理

SimpleDateFormat是java.text包下的一个类,它专门用于对Date类进行格式化(将Date对象转换为指定格式的字符串)和解析(将符合格式的字符串转换回Date对象)操作。通过自定义的模式字符串,SimpleDateFormat能够灵活地控制时间的展示样式。

(二)常用模式符号

掌握以下这些模式符号,就能根据需求定制出所需的时间格式:

  • y:表示年(例如yyyy表示四位年,yy表示两位年)
  • M:表示月(MM会补两位,1 月会显示为01)
  • d:表示日(dd会补两位)
  • H:表示时(采用 24 小时制,HH会补两位)
  • m:表示分(mm会补两位)
  • s:表示秒(ss会补两位)

(三)格式化操作示例

将Date对象转换为 “yyyy - MM - dd HH:mm:ss” 格式的字符串:

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class SimpleDateFormatParseDemo {public static void main(String[] args) {String timeStr = "2025-07-23 10:20:00";SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");try {Date date = sdf.parse(timeStr);System.out.println("解析后的 Date 对象:" + date); } catch (ParseException e) {e.printStackTrace(); }}
}

运行上述代码后,时间会按照设定的格式输出,例如2025-07-23 10:15:30,大大提升了时间的可读性。

(四)解析操作示例

将符合格式的字符串转换回Date对象:

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class SimpleDateFormatParseDemo {public static void main(String[] args) {String timeStr = "2025-07-23 10:20:00";SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");try {Date date = sdf.parse(timeStr);System.out.println("解析后的 Date 对象:" + date); } catch (ParseException e) {e.printStackTrace(); }}
}

需要注意的是,在进行解析操作时,字符串的格式必须和模式严格匹配,否则会抛出ParseException异常,因此要做好异常处理工作。

三、更灵活的时间操作工具 ——Calendar 类

(一)Calendar 类特点

Calendar是java.util包下的一个抽象类,与Date类相比,它提供了更为丰富的时间操作方法,能够方便地获取、设置时间字段(如年、月、日、时等),还支持对时间进行加减运算。

(二)获取 Calendar 实例

由于Calendar是抽象类,不能直接通过new关键字来创建实例,而是需要通过getInstance方法来获取:

import java.util.Calendar;
public class CalendarDemo {public static void main(String[] args) {Calendar calendar = Calendar.getInstance(); }
}

该方法返回的是GregorianCalendar实例(即公历),能够适配大部分的使用场景。

(三)常用方法及示例

  • 获取时间字段
int year = calendar.get(Calendar.YEAR); 
int month = calendar.get(Calendar.MONTH) + 1; // 月份从 0 开始,需要加 1
int day = calendar.get(Calendar.DAY_OF_MONTH); 
int hour = calendar.get(Calendar.HOUR_OF_DAY); // 采用24小时制
int minute = calendar.get(Calendar.MINUTE); 
int second = calendar.get(Calendar.SECOND); 
System.out.println("当前时间:" + year + "年" + month + "月" + day + "日 " + hour + ":" + minute + ":" + second);
  • 设置时间
calendar.set(Calendar.YEAR, 2026); 
calendar.set(Calendar.MONTH, Calendar.JANUARY); // 直接使用常量,更具语义性
calendar.set(Calendar.DAY_OF_MONTH, 1); 
// 也可以一次性设置多个字段
calendar.set(2026, Calendar.FEBRUARY, 14, 18, 30, 0); 
  • 时间加减
calendar.add(Calendar.DAY_OF_MONTH, 7); // 将当前时间加 7 天
calendar.add(Calendar.HOUR, -3); // 将当前时间减 3 小时

这些操作使得时间调整变得灵活高效,能够轻松实现诸如计算 “一周后的时间”“三小时前的时间” 等需求。

(四)与 Date 类相互转换

  • Date转Calendar:calendar.setTime(date);
  • Calendar转Date:Date date = calendar.getTime();

通过这种转换方式,能够在两种时间表示形式之间进行切换,以适配不同 API 的需求。

四、JDK8 时间类 —— 新时代的时间处理方案

JDK8 引入了全新的时间 API(位于java.time包下),解决了 JDK7 时间类存在的诸多痛点,如线程不安全、设计复杂等问题,以下是其中的核心类介绍:

(一)LocalDate、LocalTime、LocalDateTime

  • LocalDate:专注于处理日期(年、月、日),示例如下:
import java.time.LocalDate;
public class LocalDateDemo {public static void main(String[] args) {LocalDate nowDate = LocalDate.now(); System.out.println("当前日期:" + nowDate); LocalDate 指定日期 = LocalDate.of(2025, 7, 23); int year = 指定日期.getYear(); int month = 指定日期.getMonthValue(); int day = 指定日期.getDayOfMonth(); LocalDate 加 5 天 = 指定日期.plusDays(5); LocalDate 减 3 月 = 指定日期.minusMonths(3); }
}
  • LocalTime:用于处理时间(时、分、秒、纳秒),其用法与LocalDate类似,能够获取、设置、加减时间字段。
  • LocalDateTime:融合了日期和时间的信息,功能更为全面,例如:
import java.time.LocalDateTime;
public class LocalDateTimeDemo {public static void main(String[] args) {LocalDateTime nowDateTime = LocalDateTime.now(); LocalDateTime 指定时间 = LocalDateTime.of(2025, 7, 23, 10, 30, 0); // 支持丰富的时间调整,如调整到下一个周一、设置秒数等LocalDateTime 下周一 = nowDateTime.with(TemporalAdjusters.next(DayOfWeek.MONDAY)); }
}

(二)ZoneId 与 ZonedDateTime—— 时区处理

  • ZoneId:用于表示时区,例如ZoneId.of("Asia/Shanghai")可以获取上海时区。
  • ZonedDateTime:表示带时区的时间,它结合了LocalDateTime和ZoneId,能够解决跨时区时间处理的问题:
import java.time.ZoneId;
import java.time.ZonedDateTime;
public class ZonedDateTimeDemo {public static void main(String[] args) {ZonedDateTime 上海时间 = ZonedDateTime.now(ZoneId.of("Asia/Shanghai")); ZonedDateTime 纽约时间 = ZonedDateTime.now(ZoneId.of("America/New_York")); // 时区转换ZonedDateTime 上海转纽约 = 上海时间.withZoneSameInstant(ZoneId.of("America/New_York")); }
}

(三)DateTimeFormatter—— 线程安全的格式化工具

DateTimeFormatter是 JDK8 中用于格式化和解析时间的类,它是线程安全的,可以替代SimpleDateFormat。示例如下:

import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
public class DateTimeFormatterDemo {public static void main(String[] args) {LocalDateTime now = LocalDateTime.now();DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");String formatStr = now.format(formatter); System.out.println("格式化后:" + formatStr); LocalDateTime parseTime = LocalDateTime.parse("2025-07-23 10:45:00", formatter); }
}

五、JDK7 与 JDK8 时间类对比与选择

(一)对比

  • 线程安全:JDK7 中的SimpleDateFormat是线程不安全的,而 JDK8 的时间类都是线程安全的。
  • 易用性:JDK8 时间类的方法更加直观、语义更清晰,例如LocalDate.plusDays比Calendar.add更容易理解。
  • 设计合理性:JDK8 时间类的职责单一(LocalDate负责处理日期、LocalTime负责处理时间),而 JDK7 的时间类功能较为混杂。

(二)选择建议

  • 新开发项目:优先使用 JDK8 的时间类,以享受其简洁、安全的 API。
  • 维护老项目:如果使用的是 JDK7 的时间类,要注意线程安全问题(例如对SimpleDateFormat进行加锁或使用ThreadLocal);也可以逐步将其迁移到 JDK8 的时间类,以提升代码质量。

六、总结

从 JDK7 的Date、SimpleDateFormat、Calendar,到 JDK8 的全新时间 API,Java 的时间处理能力在不断演进。在学习过程中,要理解不同类的适用场景,掌握核心方法,在实际开发中根据需求灵活选择合适的时间类。JDK8 的时间类代表了未来的发展趋势,值得深入学习和运用,从而让时间处理变得更加高效、简洁。随着对 Java 时间 API 的掌握愈发熟练,在处理日期时间相关需求时,也能更加得心应手,为构建健壮、易维护的 Java 程序奠定坚实的基础。

 

http://www.xdnf.cn/news/1172521.html

相关文章:

  • Linux基本命令
  • Python实战:基于Streamlit的股票筛选系统,实时K线图+数据缓存优化
  • 应急响应基础
  • 通用图片 OCR 到 Word API 数据接口
  • 增强LLM最后隐藏层的意义与效果
  • 代码随想录算法训练营第五十二天|图论part3
  • 分享鸢尾花数据集:iris.csv,以及简单数据分析与分类预测示例(决策树)
  • 动态IP+AI反侦测:新一代爬虫如何绕过生物行为验证?
  • PyTorch中nn.Module详解和综合代码示例
  • 【前端】ikun-pptx编辑器前瞻问题三: pptx的图片如何提取,并在前端渲染。
  • 7月23日华为机考真题第二题-200分
  • python在windows电脑找回WiFi密码
  • 前端/后端,前台/中台/后台概念区别
  • python自动化测试框架,封装方法方式
  • 【Unity编辑器开发与拓展Handles】
  • CRMEB 单商户PRO多商户通用去版权教程
  • Oracle迁移到高斯,查询字段默认小写,解决办法
  • 微软Fabric重塑数据管理:Forrester报告揭示高ROI
  • 基于Kafka实现简单的延时队列
  • BUUCTF(web)部分题解
  • 设计模式九:构建器模式 (Builder Pattern)
  • springboot 升级到3.5.x后knife4j 文档无法识别问题解决
  • 新手向:Idea的使用技巧
  • Kubernetes服务发布基础
  • 【数据结构】线性表概括
  • [特殊字符] 从数据库无法访问到成功修复崩溃表:一次 MySQL 故障排查实录
  • SQL基础⑧ | 表格篇
  • React中的antd的表格使用方法
  • 在 Ubuntu 上将 Docker 降级到版本 25.0.5 (二) 降低版本,涉及兼容性问题
  • 解决 i.MX6ULL 通过 ADB 连接时权限不足问题 not in the plugdev group