今天看到,局部内部类要使用局部变量,那么这个局部变量必须是final的
原因是final的使这个局部变量的生命周期超越了这个方法。
我的问题是: final对象的生命周期为什么可以超越定义这个对象的方法?
有一个内存区域是常量存储区。不同于栈和堆,那么这里的对象的创建和销毁是怎么进行的?
原因是final的使这个局部变量的生命周期超越了这个方法。
我的问题是: final对象的生命周期为什么可以超越定义这个对象的方法?
有一个内存区域是常量存储区。不同于栈和堆,那么这里的对象的创建和销毁是怎么进行的?
应该可以理解为 final 的对的生命周期同类的生命周期相同.
学习......
class Outer{
final int i1 = 1;
void f(){
final int i2 = 1;
int i3 = 1;
class Inner{
void f(){
i1 = 2;
i2 = 2;
//i3 = 2; 不能访问非final局部变量
}
}
}
}
谢谢大家的回帖,有的人误会了我的意思,我指的不是i1,我指的是i2。
i1是类Outer的字段。
i2总不能说是随类Outer的生命周期一起的吧。这里不能访问i3我可以理解,因为i3在Outer.f方法结束后就没有了,i3的生命周期在Ourter.f内,而类Inner
并不是Outer.f结束后就没有。
所以“原因是final的使这个局部变量的生命周期超越了这个方法”这句话解释了为什么i2就可以访问。
所以我想问问有关final对象在常量区里的生命周期是怎样进行的。
1)所谓“局部内部类”就是在对象的方法成员内部定义的类。而方法中的类,访问同一个方法中的局部变量,是天经地义的。那么为什么要加上一个final呢?
2)原因是:编译程序实现上的困难,难在何处:内部类对象的生命周期会超过局部变量的生命期。为什么?表现在:局部变量的生命期:当该方法被调用时,该方法中的局部变量在栈中被创建(诞生),当方法调用结束时(执行完毕),退栈,这些局部变量全部死亡。而:内部类对象生命期,与其它类一样,当创建一个该局部类对象后,只有没有其它人再引用它时,它才能死亡。完全可能:一个方法已调用结束(局部变量已死亡),但该局部类的对象仍然活着。即:局部类的对象生命期会超过局部变量。
3)退一万步:局部类的对象生命期会超过局部变量又怎样?问题的真正核心是:如果:局部内部类的对象访问同一个方法中的局部变量,是天经地义的,那么:只要局部内部类对象还活着,则:栈中的那些它要访问的局部变量就不能“死亡”(否则:它都死了,还访问个什么呢?),这就是说:局部变量的生命期至少等于或大于局部内部类对象的生命期。而:正是这一点是不可能做到的
4)但是从理论上:局部内部类的对象访问同一个方法中的局部变量,是天经地义的。所以:经过努力,达到一个折中结果:即:局部内部类的对象可以访问同一个方法中的局部变量,只要这个变量被定义为final.那么:为什么定义为final变可以呢?定义为final后,编译程序就好实现了:具体实现方法是:将所有的局部内部类对象要访问的final型局部变量,都成员该内部类对象中的一个数据成员。这样,即使栈中局部变量(含final)已死亡,但由于它是final,其值永不变,因而局部内部类对象在变量死亡后,照样可以访问final型局部变量。以上仅供你参考
这个问题JAVA核心技术上倒是讲过的。
我想说既然是final修饰的就应该是常量啊,常量可以修改?
不管变量是不是final,他的生命周期都在于{}中。类对象(class对象)与其它对象不同,类对象的生命周期 开始于类被加到内存中那一刻,结束于垃圾回收。
类变量(static)与类对象的生命周期相同。