前言
隨著java版本的不斷更新迭代,java
開發也可以變得甜甜的,最新版本都到java11了,但是後面版本也是不在提供商用支援,需要收費,但是java8 依然是持續免費更新使用的,後面版本也更新很快眼花繚亂,所以穩定使用還是用 java8 把既可以體驗到新功能,又不需要,煩惱升級帶來的bug
新特性
比較新的的特性就是流Stream ,和lambda表示式
圖上面就是一些常用的方法,延遲方法
,就是對資料作處理中間方法,終結方法
就是最後符合好處理的資料結束方法
延遲方法
和lambda表示式的延遲載入的原理一樣,它可以進行鏈式程式設計如list.().filter().map().limit(),可以一直點下去最後一步由方法為count
或者foreach
載入資料
stream集合遍歷forEach
遍歷list直接list.stream().forEach
進行遍歷
List<String> a=new ArrayList<>();
a.add("judy");
a.add("Tom");
//lambda表示式
a.stream().forEach(s -> System.out.println(s));
a.stream().forEach(s -> {
System.out.println(s);
System.out.println(2);
});
集合複雜物件遍歷
Student student = new Student();
student.setAddress("上海市黃浦區陸家浜路");
student.setName("judy");
student.setAge(26);
List<Student> students = new ArrayList<>();
students.add(student);
//lambda表示式
students.stream().forEach(student1 -> System.out.println(student1.name));
students.stream().forEach(student1 -> {
System.out.println(student1.name);
System.out.println(student1.age);
System.out.println(student1.address);
});
stream條件過濾filter
使用list.stream().filter()進行過濾條件,為true
條件成立才會執行下面語句
List<String> a = new ArrayList<>();
a.add("judy");
a.add("Tom");
a.add(" ");
//lambda表示式 是judy才打印
a.stream().filter(s -> s.equals("judy")).forEach(s -> System.out.println(s));
// 不是空才打印
a.stream().filter(s -> !s.isEmpty()).forEach(s -> System.out.println(s));
複雜物件多條件判斷過濾
Student student = new Student();
student.setAddress("上海市黃浦區陸家浜路");
student.setName("judy");
student.setAge(26);
List<Student> students = new ArrayList<>();
students.add(student);
//lambda表示式 學生年紀大於28才打印
students.stream().filter(student1 -> student1.getAge()>28).forEach(student1 -> System.out.println(student1.name));
//多個條件過濾,同時成立 學生姓名是以張開頭,並且長度等於3 ,lambda表示式 列印
students.stream().filter(s->s.getName().startsWith("張")).filter(s-> s.getName().length() == 3).forEach(System.out::println);
students.stream().forEach(student1 -> {
System.out.println(student1.name);
System.out.println(student1.age);
System.out.println(student1.address);
});
stream元素對映map
將stream
流中的元素對映到另一個流中,這個是在後期經常用到的,比如方法所接收的返回值是A,但是接收的卻是B
- 將String型別的流轉換為Integer 型別
Stream<String> stringStream = Stream.of("1", "2", "3", "4", "5", "6");
stringStream.map(str->Integer.parseInt(str)).forEach(System.out::println);
- 集合型別轉換
在做許可權處理要求許可權不能重複,所以list集合轉換為set集合
List<String> a = new ArrayList<>();
a.add("judy");
a.add("Tom");
a.add(" ");
a.stream().map(s -> s).collect(Collectors.toSet()).forEach(s -> System.out.printf(s));
方法需要返回的是List ,但是這裡只有List,此時就要想到stream().map
public List<String> queryNamesByIds(List<Long> ids){
List<Category> categories = this.categoryMapper.selectByIdList(ids);
return categories.stream().map(category -> category.getName()).collect(Collectors.toList());
}
List<Object>
轉化為List<Cart>
,其中List<Object>
中的Object為Cart的json物件
//查詢購物車資料(將List<Object>變成List<Cart>)
return carts.stream().map(o -> JsonUtils.parse(o.toString(),Cart.class)).collect(Collectors.toList());
stream兩個流合併成一個流contract
Stream<String> streamA = Stream.of("張無忌","張翠山");
Stream<String> streamB = Stream.of("美羊羊","喜羊羊");
//寫法1
//Stream.concat(streamA, streamB).forEach(System.out::println);
//寫法2
Stream<String> result= Stream.concat(streamA, streamB);
result.forEach(name-> System.out.println(name));