文章目录
新日期时间API出现的背景
如果我们可以跟别人说:“我们在71见面,别晚了!”那么就再简单不过了。但是我们希望时间与昼夜和四季有关,于是事情就变复杂了。JDK 1.0中包含了一个java.util.Date类,但是它的大多数方法已经在JDK 1.1引入类之后被弃用了。而并不比Date好多少。它们面临的问题是:
可变性:像日期和时间这样的类应该是不可变的。
偏移性:Date中的年份是从1900开始的,而月份都从0开始。
格式化:格式化只对Date有用java 日期精确到毫秒,则不行。
此外,它们也不是线程安全的;不能处理闰秒等。
总结:对日期和时间的操作一直是Java程序员最痛苦的地方之一。
一、新时间日期API
1) 第三次引入的API是成功的java 日期精确到毫秒,并且Java 8中引入的java.time API 已经纠正了过去的缺陷java 日期精确到毫秒-三、格式化与解析日期或时间,将来很长一段时间内它都会为我们服务。
2) Java 8 吸收了 Joda-Time 的精华,以一个新的开始为 Java 创建优秀的 API。新的 java.time 中包含了所有关于本地日期()、本地时间()、本地日期时间()、时区()和持续时间()的类。历史悠久的 Date 类新增了 () 方法,用于把 Date 转换成新的表示形式。这些新增的本地化时间日期 API 大大简化了日期时间和本地化的管理。
java.time – 包含值对象的基础包
java.time. – 提供对不同的日历系统的访问
java.time. – 格式化和解析时间和日期
java.time. – 包括底层框架和扩展特性
java.time.zone – 包含时区支持的类
【说明】:大多数开发者只会用到基础包和包,也可能会用到包。因此,尽管有68个新的公开类型,大多数开发者,大概将只会用到其中的三分之一。
1) 、、 类是其中较重要的几个类,它们的实例是不可变的对象,分别表示使用 ISO-8601日历系统的日期、时间、日期和时间。它们提供了简单的本地日期或时间,并不包含当前的时间信息,也不包含与时区相关的信息。
2)代表IOS格式(yyyy-MM-dd)的日期,可以存储 生日、纪念日等日期。
3)表示一个时间,而不是日期。
4)是用来表示日期和时间的,这是一个最常用的类之一。
【注】:ISO-8601日历系统是国际标准化组织制定的现代公民的日期和时间的表示法,也就是公历。
二、瞬时:
1) :时间线上的一个瞬时点。 这可能被用来记录应用程序中的事件时间戳。
2) 在处理时间和日期的时候,我们通常会想到年,月,日,时,分,秒。然而,这只是时间的一个模型,是面向人类的。第二种通用模型是面向机器的,或者说是连续的。在此模型中,时间线中的一个点表示为一个很大的数,这有利于计算机处理。在UNIX中,这个数从1970年开始,以秒为的单位;同样的,在Java中,也是从1970年开始,但以毫秒为单位。
3) java.time包通过值类型提供机器视图,不提供处理人类意义上的时间单位。表示时间线上的一点,而不需要任何上下文信息,例如,时区。概念上讲,它只是简单的表示自1970年1月1日0时0分0秒(UTC)开始的秒数。因为java.time包是基于纳秒计算的,所以的精度可以达到纳秒级。
4) (1 ns = 10-9 s) 1秒 = 1000毫秒 =106微秒=109纳秒
时间戳是指格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至现在的总秒数。
三、格式化与解析日期或时间
java.time.. 类:该类提供了三种格式化方法:
1) 预定义的标准格式。如:
;;
2) 本地化相关的格式。如:(.LONG)
3) 自定义的格式。如:(“yyyy-MM-dd hh:mm:ss”)
四、其它API
1) :该类中包含了所有的时区信息,一个时区的ID,如 /Paris
2) :一个在ISO-8601日历系统时区的日期时间,如 2007-12-03T10:15:30+01:00 /Paris。
3) 其中每个时区都对应着ID,地区ID都为“{区域}/{城市}”的格式,例如:
Asia/等
4) Clock:使用时区提供对当前即时、日期和时间的访问的时钟。
5) 持续时间:,用于计算两个“时间”间隔
6) 日期间隔:,用于计算两个“日期”间隔
7) : 时间校正器。有时我们可能需要获取例如:将日期调整到“下一个工作日”等操作。
8) : 该类通过静态方法(()/()/())提供了大量的常用 的实现。
程序示例:
//ZoneId:类中包含了所有的时区信息
// ZoneId的getAvailableZoneIds():获取所有的ZoneId
Set zoneIds = ZoneId.getAvailableZoneIds();
for (String s : zoneIds) {
System.out.println(s);
}
// ZoneId的of():获取指定时区的时间
LocalDateTime localDateTime = LocalDateTime.now(ZoneId.of("Asia/Tokyo"));
System.out.println(localDateTime);
//ZonedDateTime:带时区的日期时间
// ZonedDateTime的now():获取本时区的ZonedDateTime对象
ZonedDateTime zonedDateTime = ZonedDateTime.now();
System.out.println(zonedDateTime);
// ZonedDateTime的now(ZoneId id):获取指定时区的ZonedDateTime对象
ZonedDateTime zonedDateTime1 = ZonedDateTime.now(ZoneId.of("Asia/Tokyo"));
System.out.println(zonedDateTime1);
//Duration:用于计算两个“时间”间隔,以秒和纳秒为基准
LocalTime localTime = LocalTime.now();
LocalTime localTime1 = LocalTime.of(15, 23, 32);
//between():静态方法,返回Duration对象,表示两个时间的间隔
Duration duration = Duration.between(localTime1, localTime);
System.out.println(duration);
System.out.println(duration.getSeconds());
System.out.println(duration.getNano());
LocalDateTime localDateTime = LocalDateTime.of(2016, 6, 12, 15, 23, 32);
LocalDateTime localDateTime1 = LocalDateTime.of(2017, 6, 12, 15, 23, 32);
Duration duration1 = Duration.between(localDateTime1, localDateTime);
System.out.println(duration1.toDays());
//Period:用于计算两个“日期”间隔,以年、月、日衡量
LocalDate localDate = LocalDate.now();
LocalDate localDate1 = LocalDate.of(2028, 3, 18);
Period period = Period.between(localDate, localDate1);
System.out.println(period);
System.out.println(period.getYears());
System.out.println(period.getMonths());
System.out.println(period.getDays());
Period period1 = period.withYears(2);
System.out.println(period1);
// TemporalAdjuster:时间校正器
// 获取当前日期的下一个周日是哪天?
TemporalAdjuster temporalAdjuster = TemporalAdjusters.next(DayOfWeek.SUNDAY);
LocalDateTime localDateTime = LocalDateTime.now().with(temporalAdjuster);
System.out.println(localDateTime);
// 获取下一个工作日是哪天?
LocalDate localDate = LocalDate.now().with(new TemporalAdjuster() {
@Override
public Temporal adjustInto(Temporal temporal) {
LocalDate date = (LocalDate) temporal;
if (date.getDayOfWeek().equals(DayOfWeek.FRIDAY)) {
return date.plusDays(3);
} else if (date.getDayOfWeek().equals(DayOfWeek.SATURDAY)) {
return date.plusDays(2);
} else {
return date.plusDays(1);
}
}
});
System.out.println("下一个工作日是:" + localDate);
五、参考:与传统日期处理的转换
文章来源:https://blog.csdn.net/qq_39816406/article/details/124353536