你可能沒意識(shí)到Java對(duì)函數(shù)式編程的重視程度,看看Java 8加入函數(shù)式編程擴(kuò)充多少功能就清楚了。Java 8之所以費(fèi)這么大功夫引入函數(shù)式編程,原因有二:

  1. 代碼簡潔,函數(shù)式編程寫出的代碼簡潔且意圖明確,使用stream接口讓你從此告別for循環(huán)。

  2. 多核友好,Java函數(shù)式編程使得編寫并行程序從未如此簡單,你需要的全部就是調(diào)用一下parallel()方法。

這一節(jié)我們學(xué)習(xí)stream,也就是Java函數(shù)式編程的主角。對(duì)于Java 7來說stream完全是個(gè)陌生東西,stream并不是某種數(shù)據(jù)結(jié)構(gòu),它只是數(shù)據(jù)源的一種視圖。這里的數(shù)據(jù)源可以是一個(gè)數(shù)組,Java容器或I/O channel等。正因如此要得到一個(gè)stream通常不會(huì)手動(dòng)創(chuàng)建,而是調(diào)用對(duì)應(yīng)的工具方法,比如: