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