IntelliJ IDEA 老司機(jī),還沒(méi)用過(guò) Stream Trace 功能?
前言
自從 Java 8 開(kāi)始,作為程序員的我們都離不開(kāi) Stream 相關(guān)功能的使用,書(shū)寫(xiě)起來(lái)那叫一個(gè)流暢(這個(gè) feel~~)。但總是有一些時(shí)候,我們對(duì) stream 的操作所要的結(jié)果和預(yù)期不符,這就需要我們逐步調(diào)試,定位問(wèn)題
常規(guī)調(diào)試
先來(lái)看下面這段代碼:
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)入程序:

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

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

在實(shí)際業(yè)務(wù)中,我們通常對(duì)集合進(jìn)行各種 Stream 操作,我們?cè)賮?lái)個(gè)復(fù)雜一些的例子:
List<Optional<Customer>> customers = Arrays.asList(
Optional.of(new Customer("日拱一兵", 18)),
Optional.of(new Customer("卑微的小開(kāi)發(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ì)你有很大幫助,接下來(lái)會(huì)介紹更多的你不曾留意又很高級(jí)調(diào)試技巧。
你用過(guò)這個(gè)功能嗎?
你還知道哪些高級(jí)技巧?
往 期 推 薦
1、靈魂一問(wèn):你的登錄接口真的安全嗎? 2、HashMap 中這些設(shè)計(jì),絕了~ 3、在 IntelliJ IDEA 中這樣使用 Git,賊方便了! 4、計(jì)算機(jī)時(shí)間到底是怎么來(lái)的?程序員必看的時(shí)間知識(shí)! 5、這些IDEA的優(yōu)化設(shè)置趕緊安排起來(lái),效率提升杠杠的! 6、21 款 yyds 的 IDEA插件 7、真香!用 IDEA 神器看源碼,效率真高! 點(diǎn)分享
點(diǎn)收藏
點(diǎn)點(diǎn)贊
點(diǎn)在看






