1.是什么
Lambda 允許把函數(shù)作為一個(gè)方法的參數(shù)(函數(shù)作為參數(shù)傳遞進(jìn)方法中)。
2.怎么用
(parameters) -> expression
//或者
(parameters) ->{ statements; }
(1)可選類型聲明
不需要聲明參數(shù)類型,編譯器可以統(tǒng)一識(shí)別參數(shù)值。
(2)可選的參數(shù)圓括號(hào)
一個(gè)參數(shù)無需定義圓括號(hào),但多個(gè)參數(shù)需要定義圓括號(hào)。
(3)可選的大括號(hào)
如果主體包含了一個(gè)語句,就不需要使用大括號(hào)。
(4) 可選的返回關(guān)鍵字
如果主體只有一個(gè)表達(dá)式返回值則編譯器會(huì)自動(dòng)返回值,大括號(hào)需要指定明表達(dá)式返回了一個(gè)數(shù)值。
3.好不好
使用 Lambda 表達(dá)式可以使代碼變的更加簡潔緊湊,但增加了代碼的維護(hù)難度。
4. 注意事項(xiàng)
- lambda 表達(dá)式只能引用標(biāo)記了 final 的外層局部變量,這就是說不能在 lambda 內(nèi)部修改定義在域外的局部變量,否則會(huì)編譯錯(cuò)誤。
- 一個(gè)孤立的lambda表達(dá)式實(shí)際上是一個(gè)匿名函數(shù)
5.示例
下面看兩段代碼理解下:
// 1. 不需要參數(shù),返回值為 5
() -> 5
// 2. 接收一個(gè)參數(shù)(數(shù)字類型),返回其2倍的值
x -> 2 * x
// 3. 接受2個(gè)參數(shù)(數(shù)字),并返回他們的差值
(x, y) -> x – y
// 4. 接收2個(gè)int型整數(shù),返回他們的和
(int x, int y) -> x + y
// 5. 接受一個(gè) string 對象,并在控制臺(tái)打印,不返回任何值(看起來像是返回void)
(String s) -> System.out.print(s)
String[] atp = {"Rafael Nadal", "Novak Djokovic", "Stanislas Wawrinka", "David Ferrer","Roger Federer", "Andy Murray","Tomas Berdych", "Juan Martin Del Potro"};
List<String> players = Arrays.asList(atp);
// 以前的循環(huán)方式
for (String player : players) {
System.out.print(player + "; ");
}
// 使用 lambda 表達(dá)式以及函數(shù)操作(functional operation)
players.forEach((player) -> System.out.print(player + "; "));
// 在 Java 8 中使用雙冒號(hào)操作符(double colon operator)
players.forEach(System.out::println);
String[] players = {"Rafael Nadal", "Novak Djokovic", "Stanislas Wawrinka", "David Ferrer", "Roger Federer", "Andy Murray", "Tomas Berdych", "Juan Martin Del Potro", "Richard Gasquet", "John Isner"};
// 1.1 使用匿名內(nèi)部類根據(jù) name 排序 players
Arrays.sort(players, new Comparator<String>() {
@Override public int compare(String s1, String s2) { return (s1.compareTo(s2));
}
});
// 1.2 使用 lambda expression 排序 players
Comparator<String> sortByName = (String s1, String s2) -> (s1.compareTo(s2));
Arrays.sort(players, sortByName);
// 1.3 也可以采用如下形式:
Arrays.sort(players, (String s1, String s2) -> (s1.compareTo(s2))); </pre>