java新时间类

时间

java8以前使用的时间很多方法都已经废弃了,而且不是线程安全的,java8提供了一系列的时间类,这些时间类都是线程安全的

LocalDate、LocalTime、LocalDateTime

这三个关于时间的类在使用上都类似

/**
	 * LocalDate
	 */
@Test
public void test1() {
  LocalDate date1 = LocalDate.now();
  System.out.println(date1);//2020-03-30

  LocalDate plusYears = date1.plusYears(1);
  System.out.println(plusYears);//2021-03-30

  LocalDate minusDays = date1.minusDays(2);
  System.out.println(minusDays);//2020-03-28

  LocalDate date2 = LocalDate.of(2019, 3, 30);
  System.out.println(date2.getYear());//2019
}

/**
	 * LocalTime
	 */
@Test
public void test2() {
  LocalTime now = LocalTime.now();
  System.out.println(now);//21:15:23.418

  int minute = now.getMinute();
  System.out.println(minute);//15

  int second = now.getSecond();
  System.out.println(second);//23

  LocalTime of = LocalTime.of(10, 10, 10);
  System.out.println(of);//10:10:10

  LocalTime minusMinutes = of.minusMinutes(2);
  System.out.println(minusMinutes);//10:08:10

  LocalTime plusHours = of.plusHours(2);
  System.out.println(plusHours);//12:10:10
}

/**
	 * LocalDateTime
	 */
@Test
public void test3() {
  LocalDateTime now = LocalDateTime.now();
  System.out.println(now);//2020-03-30T21:20:37.961

  int minute = now.getMinute();
  System.out.println(minute);//20

  LocalDateTime plusMinutes = now.plusMinutes(20);
  System.out.println(plusMinutes);//2020-03-30T21:40:37.961

  LocalDateTime minusYears = now.minusYears(2);
  System.out.println(minusYears);//2018-03-30T21:20:37.961

  LocalDateTime of = LocalDateTime.of(2021, 3, 30, 21, 19, 50);
  System.out.println(of);//2021-03-30T21:19:50
}

时间戳

/**
	 * Instant
	 */
@Test
public void test4() {
  Instant now = Instant.now();
  System.out.println(now);//2020-03-30T13:26:10.640Z

  Instant plusSeconds = now.plusSeconds(10);
  System.out.println(plusSeconds);//2020-03-30T13:26:20.640Z

  //获取时间戳相对于1970年0时0分0秒的毫秒数
  long epochMilli = plusSeconds.toEpochMilli();
  System.out.println(epochMilli);//1585574780640
}

Duration获取时间间隔

/**
	 * Duration
	 */
@Test
public void test5() {
  Instant start = Instant.now();
  Instant end = start.plusSeconds(10);
  Duration duration = Duration.between(start, end);
  long seconds = duration.getSeconds();
  //获取时间间隔的秒数
  System.out.println(seconds);//10

  //获取时间间隔的毫秒数
  long millis = duration.toMillis();
  System.out.println(millis);//10000
}

Peroid获取日期间隔

@Test
public void test6() {
  LocalDate date1 = LocalDate.now();
  LocalDate date2 = date1.plusYears(2);
  Period period = Period.between(date1, date2);
  //获取两时间间隔的月数,指两个月份的间隔数,并不是时间间隔的总月数
  int months = period.getMonths();
  System.out.println(months);//0
}

TemporalAdjuster矫正日期

@Test
public void test7() {
  LocalDate date1 = LocalDate.now();
  System.out.println(date1);//2020-03-31

  //TemporalAdjusters类中封装了一些常用地时间矫正方法
  TemporalAdjuster next = TemporalAdjusters.next(DayOfWeek.FRIDAY);
  LocalDate date2 = date1.with(next);
  System.out.println(date2);//2020-04-03

  //自定义时间矫正器
  LocalDate date3 = date1.with(x->{
    LocalDate ld=(LocalDate)x;
    DayOfWeek dayOfWeek = ld.getDayOfWeek();
    if(dayOfWeek.equals(DayOfWeek.FRIDAY)) {
      return ld.plusDays(3);
    }else if(dayOfWeek.equals(DayOfWeek.SATURDAY)) {
      return ld.plusDays(2);
    }else {
      return ld.plusDays(1);
    }
  });
  System.out.println(date3);//2020-04-01
}

由于TemporalAdjuster是一个函数式接口,所以我们可以使用lambda表达式自定义矫正规则

@FunctionalInterface
public interface TemporalAdjuster {
  Temporal adjustInto(Temporal temporal);
}

DateTimeFormatter格式化日期时间

@Test
public void test8() {
  LocalDateTime dateTime1 = LocalDateTime.now();
  System.out.println(dateTime1);//2020-03-31T18:28:04.256

  DateTimeFormatter formatter1 = DateTimeFormatter.ISO_DATE;
  String format1 = dateTime1.format(formatter1);
  System.out.println(format1);//2020-03-31

  DateTimeFormatter formatter2 = DateTimeFormatter.ofPattern("yyyy年MM月dd日HH时mm分ss秒");
  String format2 = dateTime1.format(formatter2);
  System.out.println(format2);//2020年03月31日18时28分04秒

  LocalDateTime dateTime2 = LocalDateTime.parse(format2, formatter2);
  System.out.println(dateTime2);//2020-03-31T18:28:04
}

ZoneDate

@Test
public void test9() {
  //获取可用时区
  ZoneId.getAvailableZoneIds().forEach(System.out::println);

  LocalDate date1 = LocalDate.now(ZoneId.of("Asia/Tokyo"));
  System.out.println(date1);//2020-03-31
}

ZoneTime

@Test
public void test10() {
  LocalTime time1 = LocalTime.now(ZoneId.of("Asia/Tokyo"));
  System.out.println(time1);//19:44:15.228

  OffsetTime atOffset = time1.atOffset(ZoneOffset.ofHours(2));
  System.out.println(atOffset);//19:44:15.228+02:00
}

ZoneDateTime

@Test
public void test11() {
  LocalDateTime dateTime1 = LocalDateTime.now(ZoneId.of("Asia/Shanghai"));
  System.out.println(dateTime1);//2020-03-31T18:51:07.136

  ZonedDateTime atZone = dateTime1.atZone(ZoneId.of("Asia/Shanghai"));
  System.out.println(atZone);//2020-03-31T18:51:07.136+08:00[Asia/Shanghai]	+09:00表示时间比格林尼治时间快9小时
}

原文地址:https://www.cnblogs.com/moyuduo/p/12629419.html

时间: 2024-10-19 18:49:01

java新时间类的相关文章

java日期时间类总结

日期时间类总结 一. Date类 Date类对象的创建: 1.创建一个当前时间的Date对象 //创建一个代表系统当前日期的Date对象 Date d = new Date(); 2.创建一个我们指定的时间的Date对象: 使用带参数的构造方法Date(int year, int month, int day) ,可以构造指定日期的Date类对象,Date类中年份的参数应该是实际需要代表的年份减去1900,实际需要代表的月份减去1以后的值. //创建一个代表2014年6月12号的Date对象 D

Java LocalDateTime,DateTimeFomatter----JDK8新时间类的简单使用

JDK8中增加了一系列时间的类, (据说)是为了干掉过去的Date,Calendar类的, 过去的Date类(据说)有着线程不安全等诸多弊端, 至于我的个人感受就是用起来实在是很麻烦,我一般封装成几个常用的方法以后每次就调方法,再也不想看里面是怎么实现的了. 而发现了LocalDateTime这种新类以后,经过我的简单的试用,觉得完全可以取代掉之前使用时间的一切方法.非常好用,太好用了. 下面是简单的使用教程: 1,按照自由格式获取当前时间 public static String getTod

java中时间类(util Date)的后延与前推处理

当后延或者前推的天数在一定时间之内时,可以用以下方法处理 public static Date  getValidEndTime(Date date,int validDayCount){ SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); String datestr = sdf.format(date); try { date = sdf.parse(datestr); } catch (ParseException

java 时间类Date和Calendar

Java的时间类经常用到,主要是两个类Date和Calendar,分别做下介绍. 一.Date 1.在 package java.util 类定义如下: public class Date implements java.io.Serializable, Cloneable, Comparable<Date>{} 类 Date 表示特定的瞬间,精确到毫秒. 在 JDK 1.1 之前,类 Date 有两个其他的函数.它允许把日期解释为年.月.日.小时.分钟和秒值.它也允许格式化和解析日期字符串.

Java日期时间API系列8-----Jdk8中java.time包中的新的日期时间API类的LocalDate源码分析

目录 0.前言 1.TemporalAccessor源码 2.Temporal源码 3.TemporalAdjuster源码 4.ChronoLocalDate源码 5.LocalDate源码 6.总结 0.前言 通过前面Java日期时间API系列6-----Jdk8中java.time包中的新的日期时间API类中主要的类关系简图如下: 可以看出主要的LocalDate, LocalTime, LocalDateTime, Instant都是实现相同的接口,这里以LocalDate为例分析jav

Java日期时间API系列11-----Jdk8中java.time包中的新的日期时间API类,使用java8日期时间API重写农历LunarDate

通过Java日期时间API系列7-----Jdk8中java.time包中的新的日期时间API类的优点,java8具有很多优点,现在网上查到的农历转换工具类都是基于jdk7及以前的类写的,下面使用java新的日期时间API重写农历LunarDate. package com.xkzhangsan.time; import java.time.Instant; import java.time.LocalDate; import java.time.LocalDateTime; import ja

Java日期时间API系列17-----Jdk8中java.time包中的新的日期时间API类,java日期计算4,2个日期对比,获取相差年月日部分属性和相差总的天时分秒毫秒纳秒等

通过Java日期时间API系列9-----Jdk8中java.time包中的新的日期时间API类的Period和Duration的区别 ,可以看出java8设计非常好,新增了Period和Duration类,专用于对比2个时间场景: Period,可以获取2个时间相差的年月日的属性. Duration,可以获取2个时间相差总的天时分秒毫秒纳秒. 下面应用: /** * 获取2个日期的相差年月天的年数部分 * @param startInclusive * @param endExclusive

Java日期时间API系列20-----Jdk8中java.time包中的新的日期时间API类,ZoneId时区ID大全等。

Java日期时间API系列19-----Jdk8中java.time包中的新的日期时间API类,ZonedDateTime与ZoneId和LocalDateTime的关系,ZonedDateTime格式化和时区转换等.中已经对ZoneId说明,并列出了常用时区ID信息. 并且通过 java.time.ZoneId.getAvailableZoneIds()获取到所有可用时区ID. 1.测试代码 /** * 获取可用时区ID */ @Test public void getAvailableZon

Java日期时间API系列19-----Jdk8中java.time包中的新的日期时间API类,ZonedDateTime与ZoneId和LocalDateTime的关系,ZonedDateTime格式化和时区转换等。

通过Java日期时间API系列6-----Jdk8中java.time包中的新的日期时间API类中时间范围示意图:可以很清晰的看出ZonedDateTime相当于LocalDateTime+ZoneId. ZonedDateTime是用来处理时区相关的时间,它的各种计算都离不开ZoneId.先看ZoneId. 1. ZoneId 为时区ID,比如Europe/Paris,表示欧洲巴黎时区 1.1 时区相关知识,时区,UTC时间,GMT时间,Unix时间戳 时区 地球自西向东旋转,东边比西边先看到