Java 内部类中使用局部变量必须是final
2015-11-30 13:57
155 查看
在java中, 方法的内部类可以访问方法中的局部变量,但必须用final修饰才能访问。
原因:
1.当方法被调用运行完毕之后,局部变量就已消亡了。但内部类对象可能还存在, 直到没有被引用时才会消亡。此时就会出现一种情况,就是内部类要访问一个不存在的局部变量。
2.解决这一问题的办法就是使用final修饰局部变量,通过将final局部变量"复制"一份,复制品直接作为方法内部类中的数据成员,这事方法内部类访问的其实是这个局部变量的复制品! 而且,由于被final修饰的变量赋值后不能再修改,所以就保证了复制品与原始变量的一致。
3.原因二的功能能实现的原因是:Java采用了一种copy local variable(复制局部变量)的方式来实现,也就是说把定义为final的局部变量拷贝过来用,而引用的也可以拿过来用,只是不能重新赋值。从而造成了可以access local
variable(访问局部变量)的假象,而这个时候由于不能重新赋值,所以一般不会造成不可预料的事情发生。
4. 使用final修饰符不仅会保持对象的引用不会改变, 而且编译器还会持续维护这个对象在回调方法中的生命周期. 所以这才是final变量和final参数的根本意义.
原因:
1.当方法被调用运行完毕之后,局部变量就已消亡了。但内部类对象可能还存在, 直到没有被引用时才会消亡。此时就会出现一种情况,就是内部类要访问一个不存在的局部变量。
2.解决这一问题的办法就是使用final修饰局部变量,通过将final局部变量"复制"一份,复制品直接作为方法内部类中的数据成员,这事方法内部类访问的其实是这个局部变量的复制品! 而且,由于被final修饰的变量赋值后不能再修改,所以就保证了复制品与原始变量的一致。
3.原因二的功能能实现的原因是:Java采用了一种copy local variable(复制局部变量)的方式来实现,也就是说把定义为final的局部变量拷贝过来用,而引用的也可以拿过来用,只是不能重新赋值。从而造成了可以access local
variable(访问局部变量)的假象,而这个时候由于不能重新赋值,所以一般不会造成不可预料的事情发生。
4. 使用final修饰符不仅会保持对象的引用不会改变, 而且编译器还会持续维护这个对象在回调方法中的生命周期. 所以这才是final变量和final参数的根本意义.
相关文章推荐
- 运算符优先级-Java 运算符优先级
- spring开发中commons-logging.jar包的功能
- Eclipse SVN 插件使用
- spring DATA (jpa) @query 和JdbcTemplate
- Spring中初始化二
- Eclipse:带库文件、自定义控件的Android项目修改包名,绝对管用简单!
- Java Cache系列之Cache概述和Simple Cache
- java不定参数"..."详解
- Java 8 vs. Scala(二):Stream vs. Collection
- springMVC前台向后台传值三种方法
- Java 8 vs. Scala(二):Stream vs. Collection
- SpringMVC 使用JSR-303进行校验 @Valid
- Spring做初始化工作一
- Java语法基础(一)
- struts 2的Ajax支持
- java中参数传递讲解(值传递和引用传递)
- springMVC+Mybatis中的ModelMap与ModelAndView
- Spring-Mock--用于Spring 的单元测试
- DBCP JAVA 连接池
- Java 8 vs. Scala(一): Lambda表达式