- 静态内部类
- 成员内部类
- 匿名内部类
- 局部内部类
package com.jarvis.java.inner;
import lombok.Data;
import java.math.BigInteger;
/**
* @author jinzhaopo
* @date 2024-01-18 16:28
*/
@Data
public class InnerClass {
@Data
private static class StaticInnerClass {
private int i;
}
@Data
private class FieldInnerClass {
private int i;
}
public static void main(String[] args) {
//静态内部类
StaticInnerClass staticInnerClass = new StaticInnerClass();
//成员内部类
InnerClass innerClass = new InnerClass();
FieldInnerClass fieldInnerClass = innerClass.new FieldInnerClass();
//匿名内部类
new Thread(new Runnable() {
@Override
public void run() {
System.out.println("匿名内部类");
}
}).start();
//局部内部类
BigInteger count = BigInteger.ONE;
count = BigInteger.TEN;
@Data
class MainInnerClass {
private void showOut() {
//编译异常,有没有想过,为什么外面的count需要加final
// System.out.println(count.intValue());
}
}
new Thread(new Runnable() {
@Override
public void run() {
new MainInnerClass().showOut();
}
});
}
}
问题:看注释,有没有想过,为什么内部类使用外部类对象,进行操作的时候,需要加final?
- 首先内部类和外部count的生命周期会有不同。在线程执行showOut方法的时候,main方法可能执行完毕了。main方法栈针都出栈了。这个时候执行showOut方法,count.intValue()的值从哪里来?
- 针对这个生命周期不一致的问题,java中给出的解决方法是:如果内部类使用了外部对象,那么,在内部类中copy一份外部对象的数据。也就是说,在内部类中会有一份一模一样的count数据。这样生命周期的问题就解决了。但是又出现新的问题:如果外部对象被修改了,那么不是内外数据不一致了?
- 所以针对copy时候内外数据不一致的问题,我们需要加上final防止。当然这里的数据不一致,只是指对象的引用,对象内部的值可以修改。