首先,内部类和外部类其实是处于同一个级别,内部类不会因为定义在方法中就会随着方法的执行完毕而跟随者被销毁。问题就来了,如果外部类的方法中的变量不定义final,那么当外部类方法执行完毕的时候,这个局部变量肯定也就被GC了,然而内部类的某个方法还没有执行完,这个时候他所引用的外部变量已经找不到了。如果定义为final,java会将这个变量复制一份作为成员变量内置于内部类中,这样的话,由于final所修饰的值始终无法改变,所以这个变量所指向的内存区域就不会变。
final
final可以修饰 类,成员变量(属性和方法),局部变量,
被final修饰的类,不能被继承,
被final修饰的方法,不能被重写,
被final修饰的全局变量,只能声明时显示赋值(或通过构造函数显示赋值),一但赋值就不能改变,成为常量。
被final修饰的局部变量,标记的局部变量可以只声明不赋值,然后再进行一次性的赋值,赋值后不可以改变。
例如:方法(){
final int x;
x=1;
}
在局部内部类中
局部变量,被final修饰后,生命周期变长,当方法结束后,变量依然存在,所以内部类可以访问fianl修饰的变量;
原理:每个内部类对象拷贝了被final修饰的变量的值。(参考网上)这样即使方法没有了,变量依然可以调用变量。
当final修饰对象时,是指引用变量不能变,引用变量所指向的对象中的内容还是可以改变的。
例如,对于如下语句:(引致 黑马面试)
Final StringBuffera=newStringBuffer("immutable");
执行如下语句将报告编译期错误:
a=newStringBuffer("");
但是,执行如下语句则可以通过编译:
a.append(" broken!");
有人在定义方法的参数时,可能想采用如下形式来阻止方法内部修改传进来的参数对象:
public void method(final StringBuffer param)
{
}
实际上,这是办不到的,在该方法内部仍然可以增加如下代码来修改参数对象:
param.append("a");
关于final的疑问:
没有内部类的final修饰的局部变量,在方法结束时还存在吗?希望高手指点一下