简介:
1.Lambda表达式是Java SE 8中一个重要的新特性。lambda表达式允许你通过表达式来代替功能接口。 lambda表达式就和方法一样,它提供了一个正常的参数列表和一个使用这些参数的主体(body,可以是一个表达式或一个代码块)。
2.Lambda表达式还增强了集合库。 Java SE 8添加了2个对集合数据进行批量操作的包: java.util.function 包以及java.util.stream 包。 流(stream)就如同迭代器(iterator),但附加了许多额外的功能。 总的来说,lambda表达式和 stream是自Java语言添加泛型(Generics)和注解(annotation)以来最大的变化。
Lambda表达式的语法 基本语法:
(parameters) -> expression
或
(parameters) ->{ statements; }
最简单的一个例子
// 1. 不需要参数,返回值为 5
() -> 5
// 2. 接收一个参数(数字类型),返回其2倍的值
x -> 2 * x
// 3. 接受2个参数(数字),并返回他们的差值
(x, y) -> x – y
// 4. 接收2个int型整数,返回他们的和
(int x, int y) -> x + y
// 5. 接受一个 string 对象,并在控制台打印,不返回任何值(看起来像是返回void)
(String s) -> System.out.print(s)
基本lambad表达式 foreach的使用
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);
// 以前的循环方式
for (String player : players) {
System.out.print(player + "; ");
}
// 使用 lambda 表达式以及函数操作(functional operation)
players.forEach((player) -> System.out.print(player + "; "));
// 在 Java 8 中使用双冒号操作符(double colon operator)
players.forEach(System.out::println);
匿名内部类中lambad表达式的运用
例子:使用lambads 来实现 Runnable接口
// 1.1使用匿名内部类
new Thread(new Runnable() {
@Override
public void run() {
System.out.println("Hello world !");
}
}).start();
// 1.2使用 lambda expression
new Thread(() -> System.out.println("Hello world !")).start();
// 2.1使用匿名内部类
Runnable race1 = new Runnable() {
@Override
public void run() {
System.out.println("Hello world !");
}
};
// 2.2使用 lambda expression
Runnable race2 = () -> System.out.println("Hello world !");
// 直接调用 run 方法(没开新线程哦!)
race1.run();
race2.run();
lambad操作集合
map使用
List<String> stringList = new ArrayList<>();
stringList.add("abc");
stringList.add("def");
stringList.add("ghi");
List<String> upStringList = stringList.stream().map(item -> item.toUpperCase()+"JAVA").collect(Collectors.toList());
upStringList.forEach(item->{System.out.println(item);});
List<Integer> listint = new ArrayList<Integer>();
listint.add(1);
listint.add(2);
listint.add(3);
listint.add(4);
listint.add(5);
IntSummaryStatistics stat = listint.stream().mapToInt((item)->item).summaryStatistics();
System.out.println("max:"+stat.getMax());
System.out.println("min:"+stat.getMin());
System.out.println("sum:"+stat.getSum());
System.out.println("count:"+stat.getCount());
System.out.println("average:"+stat.getAverage());
filter使用
List<Integer> listint = new ArrayList<Integer>();
listint.add(1);
listint.add(2);
listint.add(3);
listint.add(4);
listint.add(5);
List<Integer> collect = listint.stream().filter((item) ->(item > 1)).collect(Collectors.toList());
collect.forEach(item->{System.out.println(item);});
上一个操作中 可以使用limit来限制结果的个数:
List<Integer> collect = listint.stream().filter((item) ->(item > 1)).limit(2).collect(Collectors.toList());
当然了 也可以使用自定义过滤器
Predicate<Integer> itemFilter = (item) -> (item > 2);
List<Integer> listint = new ArrayList<Integer>();
listint.add(1);
listint.add(2);
listint.add(3);
listint.add(4);
listint.add(5);
List<Integer> collect = listint.stream().filter(itemFilter).collect(Collectors.toList());
collect.forEach(item->{System.out.println(item);});
同样也可以指定多个过滤器
Predicate<Integer> itemFilter1 = (item) -> (item > 2);
Predicate<Integer> itemFilter2 = (item) -> (item < 5);
List<Integer> listint = new ArrayList<Integer>();
listint.add(1);
listint.add(2);
listint.add(3);
listint.add(4);
listint.add(5);
List<Integer> collect = listint.stream().filter(itemFilter1).filter(itemFilter2).collect(Collectors.toList());
collect.forEach(item->{System.out.println(item);});
获取最大的那个元素
List<Integer> listint = new ArrayList<Integer>();
listint.add(1);
listint.add(2);
listint.add(3);
listint.add(4);
listint.add(5);
Integer target = listint.stream().max((item1, item2) -> (item1-item2)).get();
System.out.println(target);
collect 方法
List<Integer> listint = new ArrayList<Integer>();
listint.add(1);
listint.add(2);
listint.add(3);
listint.add(4);
listint.add(5);
Set<Integer> collect = listint.stream().collect(Collectors.toSet());
TreeSet<Integer> collect1 = listint.stream().collect(toCollection(TreeSet::new));
System.out.println(collect);
System.out.println(collect1);
并行操作:
List<Integer> listint = new ArrayList<Integer>();
listint.add(1);
listint.add(2);
listint.add(3);
listint.add(4);
listint.add(5);
Predicate<Integer> itemFilter1 = (item) -> (item > 2);
Integer result = listint.stream()
.filter(itemFilter1)
.map((item) -> (item + 1))
.max((item1, item2) -> (item1 - item2))
.get();
System.out.println(result);
lambad表达式的主要操作就是这些了 在实际开发中还是挺实用。欢迎补充哦~~~