亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么使用IntelliJ調試Java Streams

發布時間:2022-03-11 17:23:21 來源:億速云 閱讀:125 作者:iii 欄目:web開發

本篇內容主要講解“怎么使用IntelliJ調試Java Streams”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“怎么使用IntelliJ調試Java Streams”吧!

原理

讓我們從一個簡單的 Stream 開始,我們可以在 IntelliJ 為其創建一個基本的 Stream debugger:

.sorted()

.collect(toList());

上面的代碼創建了一個由字符串 “A”、“B”、“C”組成的 Stream。緊接著對這個 Stream 進行 sorted() 操作,從而創建了一個新的 Stream(至少在 Java 8-10 中是這樣),其中的元素是第一個 Stream 的元素按字母排序的結果。也就是說,第二個 Stream 包含“A”、“B”、“C”三個元素。最后,這些將元素放到一個 List 中。

Stream<String> s0 = Stream.of("C", "B", "A"); // "C", "A", "B"

Stream<String> s1 = s0.sorted(); // "A", "B", "C"

List<String> strings = s1.collect(toList()); // [“A”, “B”, “C”]

這大體上演示了 Stream debugger 如何工作。它將一個 stream 管道操作分割成多個代碼片段,一步一步地調用中間運算操作,從而可以保留每一步操作的元素內容以供分析。

Stream.of("C", "B", "A")

.peek(saveStep(0))

.sorted()

.peek(saveStep(1))

.collect(toList()); // The final result is saved to step 2

注意:真正的技術實現并不是上面這樣,它只是提供了很好的概覽。

在 IntelliJ&rsquo;s debugger 中有更加形象化的表示:

它簡潔明了地展示了 Stream 管道里的每個中間操作細節,以及最后結果。

調用

想調用 stream debugger 的話,首先要在 Stream 定義處設置斷點:

然后,啟動調試會話(以 debug 模式運行):

當到達斷點時,可以按指定的按鈕(可能有些不好找)來調用 Stream debugger,下面用紅圈標出:

這樣就打開了 stream debugger,和上文所展示的一樣。

數據庫 Streams

我將使用 Speedment(stream ORM),它允許通過標準的 Java Streams 操作來查詢數據庫,因此也能通過 IntelliJ 來調試操作。可以通過 Speedment initializer 來創建一個 Speedment 項目。

可以通過下面方式創建一個 Java 應用。

Speedment app = new SakilaApplicationBuilder()

.withPassword("sakila-password") // Replace with your own password

.build();

FilmManager films = app.getOrThrow(FilmManager.class);

現在我們可以對數據庫“film”表進行 stream 操作。下面是個例子:

List<Film> map = films.stream()

.filter(Film.LENGTH.equal(60))

.sorted(Film.RATING.reversed())

.collect(toList());

代碼將從所有 Film(電影) 對象中篩選出長度為 60 分鐘的,然后通過 Film.RATING(評級)對這些 Film 對象進行排序(降序),最后將所有元素放入一個 List。

我們調用 Stream debugger 時,會看到下面這張圖:

我們可以看到,初始 stream 中有 1000 部電影。篩選操作后,只剩 8 部電影,緊接著排序并放到一個 List。

計算統計

假設我們要計算所有 PG-13 級別(電影分級制度中的一種)電影的最小時長、最大時長以及平均時長。代碼如下:

IntSummaryStatistics stat = films.stream()

.filter(Film.RATING.equal("PG-13"))

.mapToInt(Film.LENGTH.asInt())

.summaryStatistics();

可以看出,我們可以與 Stream debugger 交互,并在 stream 管道中點擊元素來高亮顯示,也可以在元素間滾動查看單個操作步驟。

Speedment 優化了數據庫 Stream 中間操作,并將其融合進 SQL 查詢。但使用 Stream debugger 時,優化并沒有生效,以便讓我們可以看到 Stream 管道中的所有操作步驟。

到此,相信大家對“怎么使用IntelliJ調試Java Streams”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

两当县| 密云县| 千阳县| 紫云| 昭平县| 离岛区| 吴堡县| 广东省| 无锡市| 普宁市| 吉木乃县| 金坛市| 建始县| 申扎县| 和田市| 永和县| 都昌县| 永嘉县| 天等县| 会同县| 当阳市| 广水市| 惠安县| 绥芬河市| 巴彦县| 辽宁省| 南投市| 丽江市| 长沙市| 庄河市| 贵定县| 于都县| 大同市| 彭州市| 山东省| 红河县| 武强县| 竹溪县| 呈贡县| 塔河县| 澄江县|