文档介绍:Java 编译原理 Java 比 C++ 更容易理解 OOP 的思想,毕竟 C++ 还混合了不少面向过程的成分。很多人都能背出来 Java 语言的特点,所谓的动态加载机制等等。当然概念往往是先记住而后消化的,可有多少人真正去体会过动态加载的机制,试图去寻找过其中的细节呢?提供大家一个方法: 在命令行窗口运行 Java 程序的时候,加上这个很有用的参数: java verbose *.class 这样会清晰的打印出被加载的类文件,大部分是 jdk 自身运行需要的,最后几行会明显的看到自己用到的那几个类文件被加载进来的顺序。即使你声明了一个类对象,不实例化也不会加载,说明只有真正用到那个类的实例即对象的时候,才会执行加载。这样是不是大家稍微能明白一点动态加载了呢? ^_^ class 文件原理建议大家在入门的时候在命令行窗口编译和运行,不要借助 JCreator 或者 Eclipse 等 IDE 去帮助做那些事情。尝试自己这样做: javac -classpath yourpath *.java java -classpath yourpath *.class 也许很多人都能看懂,设置 classpath 的目的就是告诉编译器去哪里寻找你的 class JVM 去查询类的原理,编译器加载类要依靠 classloader ,而 classloader 有3个级别,从高到低分别是 BootClassLoader( 名字可能不准确), ExtClassLoader, AppClassLoader. 这3个加载器分别对应着编译器去寻找类文件的优先级别和不同的路径: BootClassLoade r对应 jre/classe s 路径,是编译器最优先寻找 class 的地方。 ExtClassLoader 对应 jre/lib/ext 路径,是编译器次优先寻找 clas s 的地方, AppClassLoader 对应当前路径,所以也是编译器默认找 class 的地方其实大家可以自己写个程序简单的测试,对任何 class ,例如 A,调用 new A().getClass().getClassLoader().toString() 打印出来就可以看到,把 class 文件放在不同的路径下再次执行,就会看到区别。特别注意的是如果打印出来是 nul l就表示到了最高级 BootClassLoader, 因为它是 C++ 编写的,不存在 Java 对应的类加载器的名字。寻找的顺序是一种向上迂回的思想,即如果本级别找不到,就只能去本级别之上的找,不会向下寻找。不过似乎从 到 这一特点又有改变,没有找到详细资料。所以就不举例子了。告诉大家设计这种体系的是 Sun 公司曾经的技术核心宫力先生,一个纯种华人哦! 这样希望大家不至于迷惑为什么总报错找不到类文件,不管是自己写的还是导入的第三方的 jar 文件( J2e e 中经常需要导入的)。 jdk 和 jre 大家肯定在安装 JDK 的时候会有选择是否安装单独的 jre ,一般都会一起安装,我也建议大家这样做。因为这样更能帮助大家弄清楚它们的区别: Jre 是 java runtime environment, 是 ja