将匿名类(实现一种方法)重构为lambda表达式,可使您的代码更简洁明了。 例如,这是
Runnable
及其lambda等效项的匿名类:
// using an anonymous class
Runnable r = new Runnable() {
@Override
public void run() {
System.out.println("Hello");
}
};
// using a lambda expression
Runnable r2 = () -> System.out.println("Hello");
但是,它并不总是那么简单!
这里有一些陷阱:
1.不同的作用域规则
匿名类和lambda表达式之间有不同的作用域规则。 例如,在lambda表达式中,
this
和
super
在词法上是作用域的,这意味着它们是相对于封闭类的,而在匿名类中,它们是相对于匿名类本身的。 同样,在lambda表达式中声明的局部变量将与在封闭类中声明的变量发生冲突,但是在匿名类中,允许它们在封闭类中对变量进行
屏蔽
。 这是一个例子: