Base64
对Base64编码的支持已经被加入到Java 8官方库中,这样不需要使用第三方库就可以进行Base64编码,例子代码如下:
1 package com.cn.yunliu.jdk8; 2 3 import java.nio.charset.StandardCharsets; 4 import java.util.Base64; 5 6 /** 7 * 8 * @author Administrator 9 * 10 * base64 编码格式 与解码 11 */ 12 public class Base64Code { 13 public static void main(String[] args) { 14 String str = "demo"; 15 //base64 encoded 把str转换成base64 bytes 16 String encoded = Base64.getEncoder().encodeToString(str.getBytes(StandardCharsets.UTF_8)); 17 System.out.println("encoded:"+encoded); 18 19 //base64 decoded 20 String decoded = new String(Base64.getDecoder().decode(encoded),StandardCharsets.UTF_8); 21 System.out.println("decoded:"+decoded); 22 } 23 }
这个例子的输出结果如下:
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吸取的教训),如果某个实例需要修改,则返回一个新的对象。
1 package com.cn.yunliu.jdk8; 2 3 import java.time.Clock; 4 import java.time.Duration; 5 import java.time.Instant; 6 import java.time.LocalDate; 7 import java.time.LocalDateTime; 8 import java.time.LocalTime; 9 import java.time.Month; 10 /** 11 * 12 * @author Administrator 13 * 14 *jdk 8 date 特性 15 */ 16 17 public class DateCode { 18 public static void main(String[] args) { 19 //localDate 只显示年月日 20 LocalDate ld = LocalDate.now(); 21 System.out.println("localdate:"+ld); 22 //LocalTime 只显示时分秒 23 LocalTime lt = LocalTime.now(); 24 System.out.println("localtime:"+lt); 25 26 //Clock类使用时区来返回当前的纳秒时间和日期,Clock可以替代System.currentTimeMillis()和TimeZone.getDefault()。 27 Clock clock = Clock.systemUTC(); 28 System.out.println("clock:"+clock); 29 Instant instant = clock.instant(); 30 System.out.println("instant:"+instant); 31 32 //localDateTime 包含了LocalDate和LocalTime的信息,但是不包含ISO-8601日历系统中的时区信息 33 LocalDateTime ldt = LocalDateTime.now(); 34 System.out.println("LocalDateTime:"+ldt); 35 36 //ZoneDateTime 它保存有ISO-8601日期系统的日期和时间,而且有时区信息。 37 38 //Duration 它持有的时间精确到秒和纳秒。这使得我们可以很容易得计算两个日期之间的不同 39 LocalDateTime start = LocalDateTime.of(2016, Month.JULY, 20, 18, 18); 40 LocalDateTime end = LocalDateTime.of(2017, Month.JULY, 20, 18, 18); 41 Duration dur = Duration.between(start, end); 42 43 System.out.println("2个时间差为:"+dur.toDays()+"day"+"\t"+dur.compareTo(Duration.ZERO)); 44 } 45 }
例子的输出结果是:
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的例子:可能为空的值或者某个类型的值:
1 package com.cn.yunliu.jdk8; 2 3 import java.util.Optional; 4 /** 5 * 6 * @author Administrator 7 *如果Optional实例持有一个非空值,则isPresent()方法返回true, 8 *否则返回false;orElseGet()方法,Optional实例持有null, 9 *则可以接受一个lambda表达式生成的默认值; 10 *map()方法可以将现有的Opetional实例的值转换成新的值; 11 *orElse()方法与orElseGet()方法类似,但是在持有null的时候返回传入的默认值。 12 */ 13 public class OptionalCode { 14 public static void main(String[] args) { 15 //Optional实例为null,isPresent返回false 16 Optional<?> fullName = Optional.ofNullable("1");//or null 17 fullName.isPresent(); 18 System.out.println(fullName.isPresent()); 19 20 //orElseGet()方法,Optional实例持有null,则可以接受一个lambda表达式生成的默认值 21 fullName.orElseGet(()->"none"); 22 System.out.println(fullName.orElseGet(()->"none")); 23 Optional<?> opt =Optional.of("1"); 24 System.out.println(opt.orElse(null)); 25 26 //map()方法可以将现有的Opetional实例的值转换成新的值; 27 fullName.map(s->"nihao").orElse("none"); 28 System.out.println(fullName.map(s->"nihao").orElse("none")); 29 } 30 }
有值得输出结果如下:
true
1
1
nihao
当fullName为null时输出结果如下:
false
none
1
none