JDK8的幾個方便快捷小知識
阿粉相信,JDK8 現在已經是非常普及的了,現在幾乎百分之七十以上的公司都已經在使用了,雖然大部分的公司都換上了 JDK8 但是對于編碼習慣來說,依然能夠看到很多屬于可以優化的代碼,畢竟使用JDK8 進行編碼的話,會讓自己的代碼看起來很優雅。阿粉今天就來看看 JDK7 和 JDK8 中的一些可以"優化"的代碼。
JDK8 的 fro 循環
既然要說for循環,那么沒有對比就沒有傷害,我們來對比一下使用 JDK7 的 for 循環和使用 JDK8 的 for 循環。
獲取List中所有人員的ID
獲取值之前我們先給原始的 List 進行賦值:
private static List<User> getList() {
User user = new User();
user.setId(UuidUtil.genLmnId());
user.setName("張三");
user.setAge(20);
user.setDeptName("開發部");
List<User> list = new ArrayList();
list.add(user);
User user2 = new User();
user2.setId(UuidUtil.genLmnId());
user2.setName("李四");
user2.setAge(21);
user2.setDeptName("財務部");
list.add(user2);
User user3 = new User();
user3.setId(UuidUtil.genLmnId());
user3.setName("王五");
user3.setAge(22);
user3.setDeptName("運維部");
list.add(user3);
return list;
}
一會我們直接調用就可以了,User對象很簡單:
@Data
class User{
private String id;
private String name;
private Integer age;
private String deptName;
}
JDK7獲取List中的Id數據:
//給List賦值
List<User> list = getList();
//新的IdList
List<String> Ids = new ArrayList<>();
for (User user: list) {
Ids.add(user.getId());
}
JDK8 獲取Id數據:
List<String> jdk8Ids = list.stream().map(User::getId).collect(Collectors.toList());
System.out.println("JDK8的獲取數據==="+JSON.toJSON(jdk8Ids));
這個時候就有的人會說,這算啥,就這點代碼?
獲取List數據中年齡大于等于21的人
傳統做法,不用想,直接遍歷,遍歷之后,判斷一下年齡是否是大于21,然后加入到新的對象中。這想法沒錯,那么我們來試試。
//給List賦值
List<User> list = getList();
//新的list
List<User> newList= new ArrayList<>();
for (User user: list) {
if (user.getAge() >= 21){
newList.add(user);
}
}
System.out.println("JDK7的獲取數據==="+JSON.toJSON(newList));
結果是對的,能準確篩選出我們要的數據:
JDK7的獲取數據===[{"deptName":"財務部","name":"李四","id":"165001403518349849","age":21},{"deptName":"運維部","name":"王五","id":"165001403518375639","age":22}]
JDK8 怎么實現?那就是filter,代碼來看看:
List<User> collect = list.stream().filter(user -> user.getAge() >= 21).collect(Collectors.toList());
System.out.println("JDK8的獲取數據==="+JSON.toJSON(collect));
我們看看數據:
JDK8的獲取數據===[{"deptName":"財務部","name":"李四","id":"165001458145431986","age":21},{"deptName":"運維部","name":"王五","id":"165001458145466505","age":22}]
這個篩選,那是非常的方便,雖然內部還是循環,但是至少讓我們在寫代碼的時候,把寫循環這一塊的內容直接給省略掉了,不用再繼續的去自己去寫循環,是不是就很便利的給自己省下了一大堆的時間。
接下來我們再給User里面放一個運維部的數據:
User user4 = new User();
user4.setId(UuidUtil.genLmnId());
user4.setName("趙六");
user4.setAge(22);
user4.setDeptName("運維部");
list.add(user4);
這時候,我們沒從數據庫端進行數據的分組,可能有時候同一個接口要給很多服務去調用,但是我們又不能為了因為數據格式要求不一致,就重新在寫一段相同的邏輯代碼,只能說是根據某些參數的不同,處理一下返回值,這時候就用到另外測操作了。
按照部門返回不同部門下的人員的數據
如果我們要用SQL,那很簡單,根據部門分組,如果要是在代碼里面呢?就用我們最簡單的User來進行分組。
JDK8 直接簡單方便:
Map<String, List<User>> collect = list.stream().collect(Collectors.groupingBy(User::getDeptName));
我們看看返回的數據:
JDK8的獲取數據==={
"開發部":[{"deptName":"開發部","name":"張三","id":"165035610923271907","age":20}],
"財務部":[{"deptName":"財務部","name":"李四","id":"165035610923228403","age":21}],
"運維部":[{"deptName":"運維部","name":"王五","id":"165035610923247204","age":22},
{"deptName":"運維部","name":"趙六","id":"165035610923285576","age":22}]}
直接分組好了展示我們想要的數據。那如果要使用JDK7 處理這種分組的情況,應該怎么處理呢?
是不是第一步要先考慮出循環出這個List里面都有哪些不同的部門,然后進行分組?
就這樣,我想想都覺得頭疼。要是能數據庫操作,那直接數據庫分組一下不就完事了,但是總是會有特殊情況需要我們去考慮的。所以,學會了絕對不吃虧。
阿粉今天說的這些簡單快捷的小知識,你會用了么?