Oracle多粒度封锁机制研究
2008-03-28 07:55
316 查看
专自:http://lineageii.iteye.com/blog/32404
匿名内部类为什么只能用final.是变量的作用域的问题,因为匿名内部类是出现在一个方法的内部的,如果它要访问这个方法的参数或者方法中定义的变量,则这些参数和变量必须被修饰为final。因为虽然匿名内部类在方法的内部,但实际编译的时候,内部类编译成Outer.Inner,这说明内部类所处的位置和外部类中的方法处在同一个等级上,外部类中的方法中的变量或参数只是方法的局部变量,这些变量或参数的作用域只在这个方法内部有效。因为编译的时候内部类和方法在同一级别上,所以方法中的变量或参数只有为final,内部类才可以引用。
以下代码为本人所写
匿名内部类为什么只能用final.是变量的作用域的问题,因为匿名内部类是出现在一个方法的内部的,如果它要访问这个方法的参数或者方法中定义的变量,则这些参数和变量必须被修饰为final。因为虽然匿名内部类在方法的内部,但实际编译的时候,内部类编译成Outer.Inner,这说明内部类所处的位置和外部类中的方法处在同一个等级上,外部类中的方法中的变量或参数只是方法的局部变量,这些变量或参数的作用域只在这个方法内部有效。因为编译的时候内部类和方法在同一级别上,所以方法中的变量或参数只有为final,内部类才可以引用。
以下代码为本人所写
package com.cxz.j2se; public class MyClass { public MyClass() { final int finalValue = 10; int not$Final = 20; MyInterface myInterface = new MyInterface() { public void functionWithoutPara() { //compile Error //System.out.println(noFinal); System.out.println(finalValue); } public void functionWithPara(int num) { System.out.println("The parameter " + num + " has been passed by the method"); } }; myInterface.functionWithoutPara(); myInterface.functionWithPara(not$Final); System.out.println(myInterface.getClass().getName()); } public static void main(String[] args) { new MyClass(); } }
相关文章推荐
- Oracle多粒度封锁机制研究
- Oracle多粒度封锁机制研究
- Oracle多粒度封锁机制研究
- Oracle多粒度封锁机制研究(一、研究锁机制的开始和基本篇)
- Oracle多粒度封锁机制研究
- Oracle多粒度封锁机制研究
- Oracle多粒度封锁机制研究
- Oracle多粒度封锁机制研究
- Oracle多粒度封锁机制研究
- Oracle DML封锁机制研究
- 转--Oracle DML封锁机制研究
- Oracle DML封锁机制研究
- Oracle多粒度封锁机制
- 通过意向锁多粒度封锁机制进行并发控制
- oracle多粒度锁机制
- ORACLE的封锁机制
- ORACLE锁机制研究
- oracle 数据库中的锁机制研究
- oracle回滚机制深入研究
- Oracle多粒度锁机制