您好,登錄后才能下訂單哦!
Stream初體驗
Stream是Java8中操作集合的一個重要特性,我們先來看看Java里面是怎么定義Stream的:
"A sequence of elements supporting sequential and parallel aggregate operations."
我們來解讀一下上面的那句話:
1、Stream是元素的集合,這點讓Stream看起來用些類似Iterator;
2、可以支持順序和并行的對原Stream進行匯聚的操作。
Stream的創建方式有很多種,除了最常見的集合創建,還有其他幾種方式。
List轉Stream
List繼承自Collection接口,而Collection提供了stream()方法。
List<Integer> list = Lists.newArrayList(1, 2, 3); Stream<Integer> stream = list.stream();
數組轉stream
對于數組,Arrays提供了stream()方法。
String[] arr = new String[]{"a", "b", "c"}; Stream<String> stream = Arrays.stream(arr);
Map轉stream
Map并不是一個序列,不是集合,沒辦法直接轉成stream(). 但entrySet()是Set,可以轉
Map<String, Object> map = Maps.newHashMap(); Stream<Entry<String, Object>> stream = map.entrySet().stream();
直接創建Stream
Stream也提供了API直接生成一個Stream,這個Stream大概可以理解成一個List。因為內部就是數組實現的。
Stream<Integer> integerStream = Stream.of(1, 2, 3);
讀取文件的Stream
用過Linux的就會對其命令行的管道符敬佩不已,一個管道符就可以源源不斷的做處理。在Java里讀取文件也可以實現類似的功能。
long uniqueWords = 0; try (Stream<String> lines = Files.lines(Paths.get("data.txt"), Charset.defaultCharset())) { uniqueWords = lines.flatMap(l -> Arrays.stream(l.split(" "))) .distinct() .count(); } catch (IOException e) { // }
通過函數來生成無限流
Stream提供了iterate來生成一個無限序列,一個基于初始值的無限序列。可以用lambda設置序列的生成規則,比如每次增加2.
Stream.iterate(0, n -> n + 2) .limit(10) .forEach(System.out::println);
再比如,斐波那契數列(Fibonacci sequence)
Stream.iterate(new int[]{0, 1}, t -> new int[]{t[1], t[0] + t[1]}) .limit(20) .map(t -> t[0]) .forEach(System.out::println);
Stream還提供了另一個generate方法來生成序列。接收一個用戶指定的生成序列函數IntSupplier.
IntSupplier fib = new IntSupplier() { private int previous = 0; private int current = 1; @Override public int getAsInt() { int oldPrevious = this.previous; int nextValue = this.previous + this.current; this.previous = this.current; this.current = nextValue; return oldPrevious; } }; IntStream.generate(fib).limit(10).forEach(System.out::println);
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。