IntelliJ IDEA 老司機,還沒用過 Stream Trace 功能?

日拱一兵發表於2021-05-18

前言

自從 Java 8 開始,作為程式設計師的我們都離不開 Stream 相關功能的使用,書寫起來那叫一個流暢(這個 feel~~)。但總是有一些時候,我們對 stream 的操作所要的結果和預期不符,這就需要我們逐步除錯,定位問題

常規除錯

先來看下面這段程式碼:

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 操作處打上斷點,逐步檢視結果,就像這樣:

我們需要各種單步除錯,不是很直觀,我們迫切的需要個一覽檢視,讓我們快速檢視我們的 Stream 結果

視覺化除錯

同樣先選擇行斷點,以 Debug 模式進入程式:

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

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

在實際業務中,我們通常對集合進行各種 Stream 操作,我們再來個複雜一些的例子:

		List<Optional<Customer>> customers = Arrays.asList(
				Optional.of(new Customer("日拱一兵", 18)),
				Optional.of(new Customer("卑微的小開發", 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 流程,檢視物件屬性等

總結

這個簡單的功能,看一遍就會,相信可以在日常的除錯中對你有很大幫助,接下來會介紹更多的你不曾留意又很高階除錯技巧

相關文章