什么是Lambda表达式的作用域规则?
Lambda表达式不引入任何新命名环境。在Lambda的body中的变量名就在一个闭包环境中被解释执行,除非在Lambda表达式的形式参数中引入新命名。紧接lambda表达式外的关键字this和super也具有相同的含义- 也就是说,它们引用的是闭包类。形式参数作为方法参数遵循相同的规则用于覆盖类和实例变量。例如,Bar的声明:
是合法的,因为在lambda参数i隐藏了的实例变量。对于局部变量,另一方面,遮蔽是不可能的,所以变量没有重新声明和分配的一般规则在使用前应用,使得方法声明
非法
原文链接:http://www.lambdafaq.org/what-are-the-scoping-rules-for-lambda-expressions/
Lambda表达式不引入任何新命名环境。在Lambda的body中的变量名就在一个闭包环境中被解释执行,除非在Lambda表达式的形式参数中引入新命名。紧接lambda表达式外的关键字this和super也具有相同的含义- 也就是说,它们引用的是闭包类。形式参数作为方法参数遵循相同的规则用于覆盖类和实例变量。例如,Bar的声明:
class Bar { int i; Foo foo = i -> i * 2; };
是合法的,因为在lambda参数i隐藏了的实例变量。对于局部变量,另一方面,遮蔽是不可能的,所以变量没有重新声明和分配的一般规则在使用前应用,使得方法声明
void bar() { int i; Foo foo = i -> i * 2; };//非法:变量i已经定义
非法
原文链接:http://www.lambdafaq.org/what-are-the-scoping-rules-for-lambda-expressions/