## 3.3 流API
筆者在這里對常見的流API做了一個簡單的歸納,但是本節并不打算全部講解——那樣只會讓我們文章的內容變得繁瑣。
筆者會在本節對幾個較難理解的點進行介紹。以下是其常見的Stream API:
- 篩選/過濾
- filter
- distinct
- limit
- skip
- 映射
- map
- flatMap
- 查找/匹配
- allMatch
- anyMatch
- noneMatch
- findFirst
- findAny
- `Optional<T>`
- `isPresent()`:返回是否包含值
- `ifPresent(Consumer block)`:在值存在時執行block的代碼塊
- `T get()`:值存在時返回值,否則拋出`NoSuchElementException`
- `T orElse(T other)`:值不存在時返回other
- 歸納
- reduce
----
| 操作 | 操作類型 | 返回類型 | 入參類型 | 函數描述符 |
| :----: | :----: | :----: | :----: | :----: |
| **filter** | 中間 | `Stream<T>` | `Predicate<T>` | `T->boolean` |
| **distinct** | 中間(有狀態,無界) | `Stream<T>` | | |
| **skip** | 中間(有狀態,有界) | `Stream<T>` | long | |
| **limit** | 中間(有狀態,有界) | `Stream<T>` | long` | |
| **map** | 中間 | `Stream<R>` | `Function` `<T, R>` | `T->R` |
| **flatMap** | 中間 | `Stream<R>` | `Function` `<T, Stream<R>>` | `T->Stream<R>` |
| **sorted** | 中間(有狀態,無界) | `Stream<T>` | `Comparator<T>` | `(T, T)->int` |
| **anyMatch** | 終端 | `boolean` | `Predicate<T>` | `T->boolean` |
| **noneMatch** | 終端 | `boolean` | `Predicate<T>` | `T->boolean` |
| **anyMatch** | 終端 | `boolean` | `Predicate<T>` | `T->boolean` |
| **allMatch** | 終端 | `boolean` | `Predicate<T>` | `T->boolean` |
| **findAny** | 終端 | `Optional<T>` | | |
| **findFirst** | 終端 | `Optional<T>` | | |
| **forEach** | 終端 | `void` | `Consumer<T>` | `T->void` |
| **collect** | 終端 | `R` | `Collector` `<T, A, R>` | |
| **reduce** | 終端(有狀態,有界) | `Optional<T>` | `BinaryOPerator` `<T>` | `(T, T)->T` |
| **count** | 終端 | `long` | | |
- 空白目錄
- 精簡版Spring的實現
- 0 前言
- 1 注冊和獲取bean
- 2 抽象工廠實例化bean
- 3 注入bean屬性
- 4 通過XML配置beanFactory
- 5 將bean注入到bean
- 6 加入應用程序上下文
- 7 JDK動態代理實現的方法攔截器
- 8 加入切入點和aspectj
- 9 自動創建AOP代理
- Redis原理
- 1 Redis簡介與構建
- 1.1 什么是Redis
- 1.2 構建Redis
- 1.3 源碼結構
- 2 Redis數據結構與對象
- 2.1 簡單動態字符串
- 2.1.1 sds的結構
- 2.1.2 sds與C字符串的區別
- 2.1.3 sds主要操作的API
- 2.2 雙向鏈表
- 2.2.1 adlist的結構
- 2.2.2 adlist和listNode的API
- 2.3 字典
- 2.3.1 字典的結構
- 2.3.2 哈希算法
- 2.3.3 解決鍵沖突
- 2.3.4 rehash
- 2.3.5 字典的API
- 2.4 跳躍表
- 2.4.1 跳躍表的結構
- 2.4.2 跳躍表的API
- 2.5 整數集合
- 2.5.1 整數集合的結構
- 2.5.2 整數集合的API
- 2.6 壓縮列表
- 2.6.1 壓縮列表的結構
- 2.6.2 壓縮列表結點的結構
- 2.6.3 連鎖更新
- 2.6.4 壓縮列表API
- 2.7 對象
- 2.7.1 類型
- 2.7.2 編碼和底層實現
- 2.7.3 字符串對象
- 2.7.4 列表對象
- 2.7.5 哈希對象
- 2.7.6 集合對象
- 2.7.7 有序集合對象
- 2.7.8 類型檢查與命令多態
- 2.7.9 內存回收
- 2.7.10 對象共享
- 2.7.11 對象空轉時長
- 3 單機數據庫的實現
- 3.1 數據庫
- 3.1.1 服務端中的數據庫
- 3.1.2 切換數據庫
- 3.1.3 數據庫鍵空間
- 3.1.4 過期鍵的處理
- 3.1.5 數據庫通知
- 3.2 RDB持久化
- 操作系統
- 2021-01-08 Linux I/O 操作
- 2021-03-01 Linux 進程控制
- 2021-03-01 Linux 進程通信
- 2021-06-11 Linux 性能優化
- 2021-06-18 性能指標
- 2022-05-05 Android 系統源碼閱讀筆記
- Java基礎
- 2020-07-18 Java 前端編譯與優化
- 2020-07-28 Java 虛擬機類加載機制
- 2020-09-11 Java 語法規則
- 2020-09-28 Java 虛擬機字節碼執行引擎
- 2020-11-09 class 文件結構
- 2020-12-08 Java 內存模型
- 2021-09-06 Java 并發包
- 代碼性能
- 2020-12-03 Java 字符串代碼性能
- 2021-01-02 ASM 運行時增強技術
- 理解Unsafe
- Java 8
- 1 行為參數化
- 1.1 行為參數化的實現原理
- 1.2 Java 8中的行為參數化
- 1.3 行為參數化 - 排序
- 1.4 行為參數化 - 線程
- 1.5 泛型實現的行為參數化
- 1.6 小結
- 2 Lambda表達式
- 2.1 Lambda表達式的組成
- 2.2 函數式接口
- 2.2.1 Predicate
- 2.2.2 Consumer
- 2.2.3 Function
- 2.2.4 函數式接口列表
- 2.3 方法引用
- 2.3.1 方法引用的類別
- 2.3.2 構造函數引用
- 2.4 復合方法
- 2.4.1 Comparator復合
- 2.4.2 Predicate復合
- 2.4.3 Function復合
- 3 流處理
- 3.1 流簡介
- 3.1.1 流的定義
- 3.1.2 流的特點
- 3.2 流操作
- 3.2.1 中間操作
- 3.2.2 終端操作
- 3.3.3 構建流
- 3.3 流API
- 3.3.1 flatMap的用法
- 3.3.2 reduce的用法
- 3.4 collect操作
- 3.4.1 collect示例
- 3.4.2 Collector接口