IntelliJ IDEA 老司機,還沒用過 Stream Trace 功能?
點擊下方“IT牧場”,選擇“設為星標”

前言
自從 Java 8 開始,作為程序員的我們都離不開 Stream 相關(guān)功能的使用,書寫起來那叫一個流暢(這個 feel~~)。但總是有一些時候,我們對 stream 的操作所要的結(jié)果和預期不符,這就需要我們逐步調(diào)試,定位問題
常規(guī)調(diào)試
先來看下面這段代碼:
public static void main(String[] args) {
Object[] res = Stream.of(1,2,3,4,5,6,7,8).filter( i -> i%2 == 0).filter( i -> i>3).toArray();
System.out.println(Arrays.toString(res));
}
我們可以在 Stream 操作處打上斷點,逐步查看結(jié)果,就像這樣:

我們需要各種單步調(diào)試,不是很直觀,我們迫切的需要個一覽視圖,讓我們快速查看我們的 Stream 結(jié)果
可視化調(diào)試
同樣先選擇行斷點,以 Debug 模式進入程序:

接下來會彈出 Stream Trace,整個 Stream 操作盡顯眼前

同樣可以點擊左下角的 Flat Mode 按鈕,將整個視圖扁平化

在實際業(yè)務中,我們通常對集合進行各種 Stream 操作,我們再來個復雜一些的例子:
List<Optional<Customer>> customers = Arrays.asList(
Optional.of(new Customer("日拱一兵", 18)),
Optional.of(new Customer("卑微的小開發(fā)", 22)),
Optional.empty(),
Optional.of(new Customer("OOT", 21)),
Optional.empty(),
Optional.of(new Customer("溫柔一刀", 23)),
Optional.empty()
);
long numberOf65PlusCustomers = customers
.stream()
.flatMap(c -> c
.map(Stream::of)
.orElseGet(Stream::empty))
.filter(c -> c.getAge() > 18)
.count();
System.out.println(numberOf65PlusCustomers);
同樣按照上面的操作得到可視化 Stream Trace 視圖,直觀了解整個 Stream 流程,查看對象屬性等

總結(jié)
這個簡單的功能,看一遍就會,相信可以在日常的調(diào)試中對你有很大幫助,接下來會介紹更多的你不曾留意又很高級調(diào)試技巧。
你用過這個功能嗎?
你還知道哪些高級技巧?
干貨分享
最近將個人學習筆記整理成冊,使用PDF分享。關(guān)注我,回復如下代碼,即可獲得百度盤地址,無套路領(lǐng)取!
?001:《Java并發(fā)與高并發(fā)解決方案》學習筆記;?002:《深入JVM內(nèi)核——原理、診斷與優(yōu)化》學習筆記;?003:《Java面試寶典》?004:《Docker開源書》?005:《Kubernetes開源書》?006:《DDD速成(領(lǐng)域驅(qū)動設計速成)》?007:全部?008:加技術(shù)群討論
加個關(guān)注不迷路
喜歡就點個"在看"唄^_^
