匿名内部类类分为:非静态匿名內部类类、静态类匿名内部类类、匿名匿名内部类类和局部匿名内部类类
1、非静态匿名内部类类对象会持有外部类的对象。其实是非靜态匿名内部类类对象依赖于外部类对象而存在,没有外部类就没有匿名内部类类有外部类不一定有匿名内部类类。这一点从匿名内部類类的使用语法上面可以看出:
如果非静态匿名内部类类不持有外部类实例那么它怎么能直接访问外部类实例呢。
2、静态匿名内部类类匿名内部类类是静态的,那么它就是类级别的类成员了不在依赖于对象而存在。所以静态匿名内部类类不能访问外部类非静态成员。这样静态匿名内部类类就不再依赖于外部类实例而存在静态匿名内部类类也就只持有外部类的类引用。
3、为什么匿名匿名内部类类访問方法内的变量必须是final修饰
匿名匿名内部类类是非静态匿名内部类类的一种,它可以访问外部类的成员且不必用final修饰,所以它也会持囿外部类对象(在安卓中时刻防止匿名内部类类导致内存泄露)
由于方法中的声明的变量,它是在方法执行时加载到栈内存中,随着方法执行结束就会被销毁释放而匿名匿名内部类类是类成员的一种,它的生命周期跟外部类是一致的这就导致方法中的变量被销毁后,匿名匿名内部类类对象还可以访问它这显然不符合逻辑。所以java这样解决使用final修饰,首先让大家都不要再改动然后匿名匿名内部类類会拷贝一份,这样保证了值的统一性在方法中的变量被释放后还是可以访问。当这个变量是引用变量的时候也是一样的。引用变量茬栈中的值是对象在堆的内存地址这样保证了访问的是同一个对象,但是这个对象还是可以修改自己堆中的值
注意:在java 1.8中,可以不用final修饰但是千万不要被误导,因为你不用final修饰在匿名匿名内部类类中修改它的值还是会导致编译报错。因为java 1.8其实会自动给它加上final
非静态匿名内部类类、匿名匿名内部类类会持有外部类对象
静态匿名内部类类不能访问外部类的非静态成员。