在匿名内部类中访问局部变量
【摘要】 一、在匿名内部类读取和修改外部局部变量在匿名内部类中可以访问一个外部变量,但不能对外部变量做出修改的操作,因为匿名内部类访问外部变量,相当于外部变量是用final关键字进行修饰。 二、局部变量作用域局部变量的作用域:局部变量是在某个方法中定义,当该方法执行完成后,局部变量也就消失了。【局部变量分配在JVM的虚拟机栈中,这部分内存空间随着程序的执行自动回收】,也即:局部变量的作用域是在 “方...
一、在匿名内部类读取和修改外部局部变量
在匿名内部类中可以访问一个外部变量,但不能对外部变量做出修改的操作,因为匿名内部类访问外部变量,相当于外部变量是用final关键字进行修饰。
二、局部变量作用域
局部变量的作用域:局部变量是在某个方法中定义,当该方法执行完成后,局部变量也就消失了。【局部变量分配在JVM的虚拟机栈中,这部分内存空间随着程序的执行自动回收】,也即:局部变量的作用域是在 “方法的范围内”。
但是,当(局部)内部类访问 局部变量 时,会扩大局部变量的作用域。看下面一个示例:
public class Test {
public static void main(String[] args) {
final String str = "hello world";
new Thread(new Runnable() {
@Override
public void run() {
try {
Thread.sleep(50);
} catch (InterruptedException e) {
e.printStackTrace();
}
for(int i = 0; i < 10; i++)
System.out.println(str);
}
}).start();
System.out.println("main thread finished");
}
}
运行结果如下:
三、总结
- 1第4行在main方法中定义了一个局部变量str,第6行定义了一个局部内部类Thread,并且在局部内部类Thread中访问 str。
- 从运行结果看,当程序执行到第19行时,main()方法就结束了,也即:主线程结束了。而主线程结束,局部变量str的生命周期也应该结束了。
- 但是,Thread线程还未结束,在Thread线程中还能够打印局部str的值。这就表明:局部变量 str 作用域被扩大了。
- 因此,如果局部变量不用 final 修饰,我们就可以在(局部)内部类中随意修改该局部变量值,而且是在 该局部变量的作用域范围之外可以看到这些修改后的值。这会导致一些问题。
- 因此,JAVA就规定(局部)内部类访问 的 局部变量必须用 final修饰,以防止更改局部变量的值。虽然没有显示的声明和final,因为这是一种隐式的声明,就和接口定义的方法默认为public一样。如果,反编译后仍会发现有final关键字。
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)