LocalDate、LocalTime、Instant、Duration、Period

1.1使用LocalDate和LocalTime

1.1.1LocalDate的创建方式和相关方法使用示例

 @Test
public void localDate() {
LocalDate date = LocalDate.of(2019, 11, 1);
int year = date.getYear();// 2019
Month month = date.getMonth();// NOVEMBER
int day = date.getDayOfMonth();// 1
DayOfWeek dow = date.getDayOfWeek();// FRIDAY
int len = date.lengthOfMonth();// 30
boolean leap = date.isLeapYear();// false
System.out.println(year + ", " + month + ", " + day + ", " + dow + ", " + len + ", " + leap); LocalDate date2 = LocalDate.now();
int year2 = date2.get(ChronoField.YEAR);//2019
int month2 = date2.get(ChronoField.MONTH_OF_YEAR);// 12
int day2 = date2.get(ChronoField.DAY_OF_MONTH);// 14
int dow2 = date2.get(ChronoField.DAY_OF_WEEK);// 6
System.out.println(year2 + ", " + month2 + ", " + day2 + ", " + dow2); //不可以写成2019-11-1 会报DateTimeParseException
LocalDate date3 = LocalDate.parse("2019-11-01");
int year3 = date3.get(ChronoField.YEAR);//2019
int month3 = date3.get(ChronoField.MONTH_OF_YEAR);// 11
int day3 = date3.get(ChronoField.DAY_OF_MONTH);// 1
int dow3 = date3.get(ChronoField.DAY_OF_WEEK);// 5
System.out.println(year3 + ", " + month3 + ", " + day3 + ", " + dow3);
}

1.1.1LocalTime对象的创建方式以及相关方法示例

    @Test
public void localTime() {
LocalTime time = LocalTime.of(11, 06, 23);
int hour = time.getHour();
int minute = time.getMinute();
int second = time.getSecond();
System.out.println(hour + ":" + minute + ":" + second);// 11:6:23 LocalTime time2 = LocalTime.now();
int hour2 = time2.get(ChronoField.HOUR_OF_DAY);
int minute2 = time2.get(ChronoField.MINUTE_OF_HOUR);
int second2 = time2.get(ChronoField.SECOND_OF_MINUTE);
System.out.println(hour2 + ":" + minute2 + ":" + second2);//当前时间 // 写13:9:22会报错,DateTimeParseException异常,可以传一个DateTimeFormatter自定义格式
LocalTime time3 = LocalTime.parse("13:09:22");
int hour3 = time3.get(ChronoField.HOUR_OF_DAY);
int minute3 = time3.get(ChronoField.MINUTE_OF_HOUR);
int second3 = time3.get(ChronoField.SECOND_OF_MINUTE);
System.out.println(hour3 + ":" + minute3 + ":" + second3);// 13:9:22
}

1.1.3LocalDateTime对象3种创建方式以及相关方法示例

Test
public void localDateTime() {
LocalDate date = LocalDate.now();
LocalTime time = LocalTime.now(); // 创建LocalDateTime
LocalDateTime dateTime = LocalDateTime.of(2019, 11, 1, 13, 32, 28);
LocalDateTime dateTime2 = LocalDateTime.of(date, time);
LocalDateTime dateTime3 = date.atTime(13, 32, 28);
LocalDateTime dateTime4 = date.atTime(time);
LocalDateTime dateTime6 = time.atDate(date); // 转化
LocalDate date2 = dateTime2.toLocalDate();
LocalTime time2 = dateTime2.toLocalTime();
}

1.1.4 机器的日期和时间格式

你可以通过向静态工厂方法ofEpochSecond传递一个代表秒数的值创建一个该类的实例。静态工厂方法ofEpochSecond还有一个增强的重载版本,它接收第二个以纳秒为单位的参数值,对传入作为秒数的参数进行调整。重载的版本会调整纳秒参数,确保保存的纳秒分片在0到999 999999之间。这意味着下面这些对ofEpochSecond工厂方法的调用会返回几乎同样的Instant对象:

Instant.ofEpochSecond(3);
Instant.ofEpochSecond(3, 0);
// 2 秒之后再加上100万纳秒(1秒)
Instant.ofEpochSecond(2, 1_000_000_000);
// 4秒之前的100万纳秒(1秒)
Instant.ofEpochSecond(4, -1_000_000_000);

正如你已经在LocalDate及其他为便于阅读而设计的日期-时间类中所看到的那样,Instant类也支持静态工厂方法now,它能够帮你获取当前时刻的时间戳。我们想要特别强调一点,Instant的设计初衷是为了便于机器使用。它包含的是由秒及纳秒所构成的数字。所以,它无法处理那些我们非常容易理解的时间单位。比如下面这段语句:

int day = Instant.now().get(ChronoField.DAY_OF_MONTH);

它会抛出下面这样的异常:

Exception in thread "main" java.time.temporal.UnsupportedTemporalTypeException: Unsupported field: DayOfMonth

你可以通过Duration和Period类使用Instant

1.1.5 定义Duration和Period(时间间隔对象)

  • Duration:可以传2个localTime对象,localDateTime对象或者Instant对象
  • Period:用年,月,日建模,可以传2个localDate对象
Duration d1 = Duration.between(time1, time2);
Duration d2 = Duration.between(dateTime1, dateTime2);
Duration d3 = Duration.between(instant1, instant2);

由 于LocalDateTime和Instant是为不同的目的而设计的,一个是为了便于人阅读使用,另一个是为了便于机器处理,所以你不能将二者混用。如果你试图在这两类对象之间创建duration,会触发一个DateTimeException异常 。 如果你需要以年、月或者日的方式对多个时间单位建模,可以使用Period类。使用该类的工厂方法between,你可以使用得到两个LocalDate之间的时长,如下所示 :

Period period = Period.between(LocalDate.of(2019, 11, 07), LocalDate.of(2019, 11, 07));

Duration和Period类都提供了很多非常方便的工厂类,直接创建对应的实例;换句话说,就像下面这段代码那样,不再是只能以两个temporal对象的差值的方式来定义它们的对象。

Duration threeMinutes = Duration.ofMinutes(3);
Duration fourMinutes = Duration.of(4, ChronoUnit.MINUTES); Period tenDay = Period.ofDays(10);
Period threeWeeks = Period.ofWeeks(3);
Period twoYearsSixMonthsOneDay = Period.of(2, 6, 1);

1.2 操纵 解析和格式化日期

1.2.1

  • 以比较直观的方式操纵LocalDate的属性

下面的这段代码中所有的方法都返回一个修改了属性的对象。它们都不会修改原来的对象!

LocalDate date1 = LocalDate.of(2019, 11, 1);//2019-11-01
LocalDate date2 = date1.withYear(2020);//2020-11-01
LocalDate date3 = date2.withDayOfMonth(25);//2020-11-25
LocalDate date4 = date3.with(ChronoField.MONTH_OF_YEAR, 9);//2020-09-25
  • 以相对方式修改LocalDate的属性
@Test
public void editDateTime() {
LocalDate date1 = LocalDate.of(2019, 11, 01);// 2019-11-01
LocalDate date2 = date1.plusWeeks(1);// 2019-11-08
LocalDate date3 = date2.minusYears(2);// 2017-11-08
LocalDate date4 = date3.plus(6, ChronoUnit.MONTHS);// 2018-05-08
}

1.2.3 TemporalAdjuster

@Test
public void adjust() {
LocalDate date1 = LocalDate.of(2019, 11, 01);// 2019-11-01
LocalDate date2 = date1.with(TemporalAdjusters.nextOrSame(DayOfWeek.SUNDAY));// 2019-11-03
LocalDate date3 = date2.with(TemporalAdjusters.lastDayOfMonth());// 2019-11-30
}

TemporalAdjuster类的工厂方法

1.2.4自定义格式化输出日期

新版本,我们拥有一个线程安全的类:DateTimeFormatter 来看代码

 @Test
public void formatPrint() {
LocalDate date = LocalDate.of(2019, 11, 01);
String s1 = date.format(DateTimeFormatter.BASIC_ISO_DATE);// 20191101
String s2 = date.format(DateTimeFormatter.ISO_LOCAL_DATE);// 2019-11-01 LocalDate date1 = LocalDate.parse("20191101", DateTimeFormatter.BASIC_ISO_DATE);
LocalDate date2 = LocalDate.parse("2019-11-01", DateTimeFormatter.ISO_LOCAL_DATE); // 自定义格式
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("dd/MM/yyyy");
String formattedDate = date.format(formatter);
System.out.println(formattedDate);// 01/11/2019
LocalDate date3 = LocalDate.parse(formattedDate, formatter); // 带时区的日期(本地化)
DateTimeFormatter italianFormatter = DateTimeFormatter.ofPattern("d. MMMM yyyy", Locale.ITALIAN);
String formattedDate2 = date.format(italianFormatter);
LocalDate date4 = LocalDate.parse(formattedDate2, italianFormatter);
}

Java8 日期和时间API的更多相关文章

  1. Java8 日期与时间 API

    在 Java 中,想处理日期和时间时,通常都会选用 java.util.Date 这个类进行处理.不过不知道是设计者在当时没想好还是其它原因,在 Java 1.0 中引入的这个类,大部分的 API 在 ...

  2. Java8系列 (六) 新的日期和时间API

    概述 在Java8之前, 我们一般都是使用 SimpleDateFormat 来解析和格式化日期时间, 但它是线程不安全的. @Test public void test() { SimpleDate ...

  3. 详解Java8的日期和时间API

    详解Java8的日期和时间API 在JDK1.0的时候,Java引入了java.util.Date来处理日期和时间:在JDK1.1的时候又引入了功能更强大的java.util.Calendar,但是C ...

  4. 计算机程序的思维逻辑 (95) - Java 8的日期和时间API

    ​本节继续探讨Java 8的新特性,主要是介绍Java 8对日期和时间API的增强,关于日期和时间,我们在之前已经介绍过两节了,32节介绍了Java 1.8以前的日期和时间API,主要的类是Date和 ...

  5. Java编程的逻辑 (95) - Java 8的日期和时间API

    ​本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http: ...

  6. 《Java 8 in Action》Chapter 12:新的日期和时间API

    在Java 1.0中,对日期和时间的支持只能依赖java.util.Date类.同时这个类还有两个很大的缺点:年份的起始选择是1900年,月份的起始从0开始. 在Java 1.1中,Date类中的很多 ...

  7. Java 8 (11) 新的日期和时间API

    在Java 1.0中,对日期和时间的支持只能依赖java.util.Date类.这个类只能以毫秒的精度表示时间.这个类还有很多糟糕的问题,比如年份的起始选择是1900年,月份的起始从0开始.这意味着你 ...

  8. java 8中新的日期和时间API

    java 8中新的日期和时间API 使用LocalDate和LocalTime LocalDate的实例是一个不可变对象,它只提供了简单的日期,并不含当天的时间信息.另外,它也不附带任何与时区相关的信 ...

  9. Java8 日期和时间类

    新的日期和时间API 新的日期和时间类解决了Date和Calendar类出现的问题 浅尝 LocalDate 日期类 LocalDate of = LocalDate.of(2018, 7, 13); ...

随机推荐

  1. EF中存储过程的使用

    存储过程即用来完成一个特定功能的一段代码.它的优缺点 优点 存储过程可封装,并隐藏复杂的商业逻辑. 存储过程可以回传值,并可以接受参数. 存储过程无法使用 SELECT 指令来运行,因为它是子程序,与 ...

  2. 压测 swoole_websocket_server 性能

    概述 这是关于 Swoole 入门学习的第十篇文章:压测 swoole_websocket_server 性能. 第九篇:Swoole Redis 连接池的实现 第八篇:Swoole MySQL 连接 ...

  3. Python 从入门到进阶之路(六)

    之前的文章我们简单介绍了一下 Python 的面向对象,本篇文章我们来看一下 Python 中异常处理. 我们在写程序时,有可能会出现程序报错,但是我们想绕过这个错误执行操作.即使我们的程序写的没问题 ...

  4. [Spring cloud 一步步实现广告系统] 4. 通用代码模块设计

    一个大的系统,在代码的复用肯定是必不可少的,它能解决: 统一的响应处理(可以对外提供统一的响应对象包装) 统一的异常处理(可以将业务异常统一收集处理) 通用代码定义.配置定义(通用的配置信息放在统一的 ...

  5. vue小案例--简易评论区

    一.小案例(评论区) 1.流程 (1)分析静态页面.(vue项目创建参考https://www.cnblogs.com/l-y-h/p/11241503.html)(2)拆分静态页面,变成一个个组件. ...

  6. GPU 编程相关 简要摘录

    GPU 编程可以称为异构编程,最近由于机器学习的火热,很多模型越来越依赖于GPU来进行加速运算,所以异构计算的位置越来越重要:异构编程,主要是指CPU+GPU或者CPU+其他设备(FPGA等)协同计算 ...

  7. requests---requests请求表单

    在做接口测试的时候我们会遇到过需要填写表单的形式,那么如何通过requests进行请求呢? 这里需要引入新的python的第3方库requests-toolbelt requests-toolbelt ...

  8. 001 C/C++ 选择排序法

    简单选择排序: 选择排序法 是对 定位比较交换法(也就是冒泡排序法) 的一种改进. 选择排序的基本思想是:每一趟在n-i+1(i=1,2,…n-1)个记录中选取关键字最小的记录作为有序序列中第i个记录 ...

  9. leetcode 5199. 交换字符串中的元素

    地址  https://leetcode-cn.com/contest/weekly-contest-155/problems/smallest-string-with-swaps/ 给你一个字符串  ...

  10. Java之匿名对象

    匿名对象概念 创建对象时,只有创建对象的语句,却没有把对象地址值赋值给某个变量.虽然是创建对象的简化写法,但是应用场景非常有限.匿名对象 :没有变量名的对象. 格式: new 类名(参数列表): // ...