回应@Jon Skeet的修辞问题:
Another class then refers to Bar, so the JVM needs the code for it… how would you suggest it finds the file?
假设(假设)Java类文件格式通过将它们嵌入最外层的类文件中来表示嵌套/内部类. Bar的二进制名称是“Lsome / pkg / Foo $Bar;”.类加载器可以将名称拆分为“$”字符,使用第一部分找到Foo的类文件,然后导航到嵌入的Bar类表示.
我认为内部/嵌套类具有单独的类文件的真正原因是历史性的. IIRC,Java 1.0不支持嵌套或内部类,因此相应的类文件格式不需要处理它们.当创建Java 1.1(支持内部/嵌套类)时,Sun希望类文件格式与Java 1.0编译器生成的类文件兼容.因此,他们选择使用二进制类名中的保留“$”字符将内部/嵌套类实现为单独的类文件.
第二个可能的原因是,与假设的嵌入格式相比,平面格式简化了类加载.
最后,他们没有令人信服的理由不使用平面文件格式.当一些程序员想要使用Class.forName()加载内部类时,它可能会产生一些小问题,但这种情况很少发生……并且解决方案是直截了当的.