IntelliJ IDEA 老司機(jī),還沒用過 Stream Trace 功能?
點(diǎn)擊下方“IT牧場(chǎng)”,選擇“設(shè)為星標(biāo)”

前言
自從 Java 8 開始,作為程序員的我們都離不開 Stream 相關(guān)功能的使用,書寫起來那叫一個(gè)流暢(這個(gè) feel~~)。但總是有一些時(shí)候,我們對(duì) stream 的操作所要的結(jié)果和預(yù)期不符,這就需要我們逐步調(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 操作處打上斷點(diǎn),逐步查看結(jié)果,就像這樣:

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

接下來會(huì)彈出 Stream Trace,整個(gè) Stream 操作盡顯眼前

同樣可以點(diǎn)擊左下角的 Flat Mode 按鈕,將整個(gè)視圖扁平化

在實(shí)際業(yè)務(wù)中,我們通常對(duì)集合進(jìn)行各種 Stream 操作,我們?cè)賮韨€(gè)復(fù)雜一些的例子:
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 視圖,直觀了解整個(gè) Stream 流程,查看對(duì)象屬性等

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