版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_42097653/article/details/80675085
-----------------------------------------------------------------------------------------------------------------------------
class Outer{ // 定义外部类
private String info = "hello world" ; // 定义外部类的私有属性
public void fun(final int temp){ // 定义外部类的方法
class Inner{ // 在方法中定义的内部类
public void print(){ // 定义内部类的方法
System.out.println("类中的属性:" + info) ; // 直接访问外部类的私有属性
System.out.println("方法中的参数:" + temp) ;
}
};
new Inner().print() ; // 通过内部类的实例化对象调用方法
}
};
public class InnerClassDemo05{
public static void main(String args[]){
new Outer().fun(30) ; // 调用外部类的方法
}
};
定义在成员位置处的类为成员内部类,而定义在局部位置处的类为局部内部类。
当内部类访问外部类的局部变量或者外部方法的局部变量/函数参数时,需要将该变量声明为最终类型。
System.out.println("方法中的参数:" + temp) ;
temp是外部方法的函数形参,那么这个参数就需要声明为最终类型。
为什么呢???
是因为fun(30)函数被调用后,函数参数等就会被内存机制回收,因为他们是被分配到栈中的。而内部类的对象是在堆中分配内存的,外部方法调用结束后该内部类对象不一定就被销毁了;所以就会出现一个奇怪的现象:内部类对象在访问一个不存在的局部变量。
这时候,用状态修饰符final修饰该变量,从而该变量成了常量,解决了这个问题。
本质: 局部变量的生命周期与局部内部类的对象的生命周期的不一致性.
参考(致谢):
https://www.cnblogs.com/ioveNature/p/7011204.html
https://blog.csdn.net/seashine_yan/article/details/67637941
————————————————
版权声明:本文为CSDN博主「thjstar」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_42097653/article/details/80675085