JDK8 特性详解

时间:2023-03-09 18:54:49
JDK8 特性详解

Base64

对Base64编码的支持已经被加入到Java 8官方库中,这样不需要使用第三方库就可以进行Base64编码,例子代码如下:

 package com.cn.yunliu.jdk8;

 import java.nio.charset.StandardCharsets;
import java.util.Base64; /**
*
* @author Administrator
*
* base64 编码格式 与解码
*/
public class Base64Code {
public static void main(String[] args) {
String str = "demo";
//base64 encoded 把str转换成base64 bytes
String encoded = Base64.getEncoder().encodeToString(str.getBytes(StandardCharsets.UTF_8));
System.out.println("encoded:"+encoded); //base64 decoded
String decoded = new String(Base64.getDecoder().decode(encoded),StandardCharsets.UTF_8);
System.out.println("decoded:"+decoded);
}
}

这个例子的输出结果如下:

encoded:ZGVtbw==
decoded:demo

新的Base64API也支持URL和MINE的编码解码。
(Base64.getUrlEncoder() / Base64.getUrlDecoder(), Base64.getMimeEncoder() / Base64.getMimeDecoder())。

Date/Time API(JSR 310)

Java 8引入了新的Date-Time API(JSR 310)来改进时间、日期的处理。时间和日期的管理一直是最令Java开发者痛苦的问题。java.util.Date和后来的java.util.Calendar一直没有解决这个问题(甚至令开发者更加迷茫)。

因为上面这些原因,诞生了第三方库Joda-Time,可以替代Java的时间管理API。Java 8中新的时间和日期管理API深受Joda-Time影响,并吸收了很多Joda-Time的精华。新的java.time包包含了所有关于日期、时间、时区、Instant(跟日期类似但是精确到纳秒)、duration(持续时间)和时钟操作的类。新设计的API认真考虑了这些类的不变性(从java.util.Calendar吸取的教训),如果某个实例需要修改,则返回一个新的对象。

 package com.cn.yunliu.jdk8;

 import java.time.Clock;
import java.time.Duration;
import java.time.Instant;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.LocalTime;
import java.time.Month;
/**
*
* @author Administrator
*
*jdk 8 date 特性
*/ public class DateCode {
public static void main(String[] args) {
//localDate 只显示年月日
LocalDate ld = LocalDate.now();
System.out.println("localdate:"+ld);
//LocalTime 只显示时分秒
LocalTime lt = LocalTime.now();
System.out.println("localtime:"+lt); //Clock类使用时区来返回当前的纳秒时间和日期,Clock可以替代System.currentTimeMillis()和TimeZone.getDefault()。
Clock clock = Clock.systemUTC();
System.out.println("clock:"+clock);
Instant instant = clock.instant();
System.out.println("instant:"+instant); //localDateTime 包含了LocalDate和LocalTime的信息,但是不包含ISO-8601日历系统中的时区信息
LocalDateTime ldt = LocalDateTime.now();
System.out.println("LocalDateTime:"+ldt); //ZoneDateTime 它保存有ISO-8601日期系统的日期和时间,而且有时区信息。 //Duration 它持有的时间精确到秒和纳秒。这使得我们可以很容易得计算两个日期之间的不同
LocalDateTime start = LocalDateTime.of(2016, Month.JULY, 20, 18, 18);
LocalDateTime end = LocalDateTime.of(2017, Month.JULY, 20, 18, 18);
Duration dur = Duration.between(start, end); System.out.println("2个时间差为:"+dur.toDays()+"day"+"\t"+dur.compareTo(Duration.ZERO));
}
}

例子的输出结果是:

localdate:2018-08-13
localtime:17:29:13.438
clock:SystemClock[Z]
instant:2018-08-13T09:29:13.453Z
LocalDateTime:2018-08-13T17:29:13.469
2个时间差为:365day 1

Optional

Java应用中最常见的bug就是空值异常。在Java 8之前,Google Guava引入了Optionals类来解决NullPointerException,从而避免源码被各种null检查污染,以便开发者写出更加整洁的代码。Java 8也将Optional加入了官方库。

Optional仅仅是一个容易:存放T类型的值或者null。它提供了一些有用的接口来避免显式的null检查,可以参考Java 8官方文档了解更多细节。

接下来看一点使用Optional的例子:可能为空的值或者某个类型的值:

 package com.cn.yunliu.jdk8;

 import java.util.Optional;
/**
*
* @author Administrator
*如果Optional实例持有一个非空值,则isPresent()方法返回true,
*否则返回false;orElseGet()方法,Optional实例持有null,
*则可以接受一个lambda表达式生成的默认值;
*map()方法可以将现有的Opetional实例的值转换成新的值;
*orElse()方法与orElseGet()方法类似,但是在持有null的时候返回传入的默认值。
*/
public class OptionalCode {
public static void main(String[] args) {
//Optional实例为null,isPresent返回false
Optional<?> fullName = Optional.ofNullable("1");//or null
fullName.isPresent();
System.out.println(fullName.isPresent()); //orElseGet()方法,Optional实例持有null,则可以接受一个lambda表达式生成的默认值
fullName.orElseGet(()->"none");
System.out.println(fullName.orElseGet(()->"none"));
Optional<?> opt =Optional.of("1");
System.out.println(opt.orElse(null)); //map()方法可以将现有的Opetional实例的值转换成新的值;
fullName.map(s->"nihao").orElse("none");
System.out.println(fullName.map(s->"nihao").orElse("none"));
}
}

有值得输出结果如下:

true
1
1
nihao

当fullName为null时输出结果如下:

false
none
1
none