你可能沒意識到Java對函數(shù)式編程的重視程度,看看Java 8加入函數(shù)式編程擴(kuò)充多少功能就清楚了。Java 8之所以費(fèi)這么大功夫引入函數(shù)式編程,原因有二:
代碼簡潔,函數(shù)式編程寫出的代碼簡潔且意圖明確,使用stream接口讓你從此告別for循環(huán)。
多核友好,Java函數(shù)式編程使得編寫并行程序從未如此簡單,你需要的全部就是調(diào)用一下
parallel()
方法。
這一節(jié)我們學(xué)習(xí)stream,也就是Java函數(shù)式編程的主角。對于Java 7來說stream完全是個陌生東西,stream并不是某種數(shù)據(jù)結(jié)構(gòu),它只是數(shù)據(jù)源的一種視圖。這里的數(shù)據(jù)源可以是一個數(shù)組,Java容器或I/O channel等。正因如此要得到一個stream通常不會手動創(chuàng)建,而是調(diào)用對應(yīng)的工具方法,比如:
調(diào)用
Collection.stream()
或者Collection.parallelStream()
方法調(diào)用
網(wǎng)友評論