前言
隨著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
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));