为什么内部类访问的外部变量需要使用final修饰

因为生命周期的原因。方法中的局部变量,方法结束后这个变量就要释放掉,final保证这个变量始终指向一个对象。

首先,内部类和外部类其实是处于同一个级别,内部类不会因为定义在方法中就会随着方法的执行完毕而跟随者被销毁。问题就来了,如果外部类的方法中的变量不定义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修饰的局部变量,在方法结束时还存在吗?希望高手指点一下


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值