jdk 1.8 新特性


五、Stream API

stream流主要对集合(Collection)进行操作。比如说我们从数据库查询出来的数据,需要做一层过滤,再比如所,我们要在结果集里对数据进行操作等,这写都需要我们做循环,再筛选,再进行操作,其实这并不难,但这些都给我们增加了大量的代码量,如果用stream流,用一行代码就可以解决我们的需求!

在jdk1.8以后,我们会发现 Collection里新增加了一个接口 Collection default Stream stream(),这说明我们的集合对象中会新增加一个方法,我们调用这个方法就可以获取到我们需要的stream流对象,我们对集合进行的操作,也都是通过这个stream流对象进行操作的。

public static void main(String[] args){ List<String> strList = new ArrayList<>(); strList.add("shaochen"); strList.add("shaohen"); strList.add("cool"); strList.add("bean"); strList.add("java"); strList.add("java"); // 这行获取我们的stream流对象,我们的操作都是通过这个流对象进行操作的。 Stream<String> stream = strList.stream(); // 首先我们做一个简单的循环遍历 stream.forEach(System.out::println); //使用stream流获取集合的长度 long count = stream.count(); //使用stream流对数据进行去重 stream.distinct().forEach(System.out::println); //将stream流处理后的数据收集成一个集合 List<String> collect = stream.distinct().collect(Collectors.toList()); //stream中的分页操作,skip代表着要跳过结果集中的前几个数据,limit也就是取结果集中的几个数据, 也就是一个是page字段,一个是size字段,可以做到简单的分页。 stream.skip(2).limit(2).forEach(s -> System.out.println(s)); //max和min 最大、小值 // 获取最大值 int max = list.stream().map((s) -> s.length()).max(Integer::compareTo).get(); // 获取最小值 int min = list.stream().min(Comparator.comparing((s) -> s.length())).get().length(); //Stream流map、filter的使用 // 将集合中的数据循环变为大写字母,然后过滤,找到包含A的数据,循环打印出来 stream.map(s -> s.toUpperCase()).filter(s -> s.contains("A")).forEach(System.out::println) } 

二、Date API

(LocalDate | LocalTime | LocalDateTime)

表示日期的LocalDate 表示时间的LocalTime 表示日期时间的LocalDateTime

在旧版的 Java 中,日期时间 API 存在诸多问题,其中有: 非线程安全 − java.util.Date 是非线程安全的,所有的日期类都是可变的,这是Java日期类最大的问题之一。新的日期API都是不可变的,更使用于多线程的使用环境中

import java.time.LocalDate; import java.time.LocalDateTime; import java.time.LocalTime; import java.time.Month; public class DateTest { public static void main(String args[]){ // 获取当前的日期时间 LocalDateTime currentTime = LocalDateTime.now(); System.out.println("当前时间: " + currentTime); //当前日期 LocalDate date1 = currentTime.toLocalDate(); System.out.println("date1: " + date1); Month month = currentTime.getMonth(); int day = currentTime.getDayOfMonth(); int seconds = currentTime.getSecond(); System.out.println("月: " + month +", 日: " + day +", 秒: " + seconds); LocalDateTime date2 = currentTime.withDayOfMonth(10).withYear(2012); System.out.println("date2: " + date2); LocalDate date3 = LocalDate.of(2014, Month.DECEMBER, 12); System.out.println("date3: " + date3); // 时间 LocalTime date4 = LocalTime.of(22, 15); System.out.println("date4: " + date4); // 解析字符串 LocalTime date5 = LocalTime.parse("20:15:30"); System.out.println("date5: " + date5); } } //输出结果 当前时间: 2020-06-12T01:46:49.803 date1: 2020-06-12 月: JUNE, : 12, : 49 date2: 2012-06-10T01:46:49.803 date3: 2014-12-12 date4: 22:15 date5: 20:15:30 

补充: 之前使用的java.util.Date月份从0开始,我们一般会+1使用,很不方便,java.time.LocalDate月份和星期都改成了enum

java.util.Date和SimpleDateFormat都不是线程安全的,而LocalDate和LocalTime和最基本的String一样,是不变类型,不但线程安全,而且不能修改。

java.util.Date是一个“万能接口”,它包含日期、时间,还有毫秒数,更加明确需求取舍

新接口更好用的原因是考虑到了日期时间的操作,经常发生往前推或往后推几天的情况。用java.util.Date配合Calendar要写好多代码,而且一般的开发人员还不一定能写对。

三、Optional API

Optional 类已经成为 Java 8 类库的一部分,用来解决空指针异常。这意味着 Optional 类既可以含有对象也可以为空。Optional 类是一个可以为null的容器对象。如果值存在则isPresent()方法会返回true,调用get()方法会返回该对象。Optional 是个容器:它可以保存类型T的值,或者仅仅保存null。Optional提供很多有用的方法,这样我们就不用显式进行空值检测。

创建对象:不允许为空
Optional提供了方法of()用于创建非空对象,该方法要求传入的参数不能为空,否则抛NullPointException,示例如下:
Optional<String> optStr = Optional.of(str);  // 当str为null的时候,将抛出NullPointException

创建对象:允许为空
如果不能确定传入的参数是否存在null值的可能性,则可以用Optional的ofNullable()方法创建对象,如果入参为null,则创建一个空对象。示例如下:
Optional<String> optStr = Optional.ofNullable(str);  // 如果str是null,则创建一个空对象

代码:

import java.util.Optional; public class Java8Tester { public static void main(String args[]){ Java8Tester java8Tester = new Java8Tester(); Integer value1 = null; Integer value2 = new Integer(10); // Optional.ofNullable - 允许传递为 null 参数 Optional<Integer> a = Optional.ofNullable(value1); // Optional.of - 如果传递的参数是 null,抛出异常 NullPointerException Optional<Integer> b = Optional.of(value2); System.out.println(java8Tester.sum(a,b)); } public Integer sum(Optional<Integer> a, Optional<Integer> b){ // Optional.isPresent - 判断值是否存在 System.out.println("第一个参数值存在: " + a.isPresent()); System.out.println("第二个参数值存在: " + b.isPresent()); // Optional.orElse - 如果值存在,返回它,否则返回默认值 Integer value1 = a.orElse(new Integer(0)); //Optional.get - 获取值,值需要存在 Integer value2 = b.get(); return value1 + value2; } } 

输出结果为:

第一个参数值存在: false
第二个参数值存在: true
10
作者:Bang
链接:https://zhuanlan.zhihu.com/p/148593621


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM