在JAVA中,当我们使用一个类时首先需要将这个类的CLASS(二进制文件)从硬盘中加载到内存来,这时就用到了类加载器。JAVA中提供了三个默认的类加载器,分别是:BootStrap,ExtClassLoader,AppClassLoader。其中,BootStrap是最顶级的加载器,它不是一个JAVA类,而是一个C++编写的二进制文件,其嵌套在JAVA虚拟机的内核中。
对于这三个加载器各自负责加载特定目录下JAVA类,当我们把自定义的JAVA类打成JAR包后放在相应的目录下就会被相应的类加载器加载。
获取JAVA类的加载器的方法:
类.getClassLoader().getClass().getName();
当我们的类的类加载器为了BootStrap时,使用 类.getClassLoader() 将返回一个null值, 因为BootStrap不一个JAVA类。
类加载的委托机制:当我们有类需要被加载时,JAVA虚拟机会将加载的任务交给当前目录上的加载器的父加载器去加载,依此类推,当父加载器没有找到要加载的类时就会把任务交给它的子加载器,如果子加载器也没有找到相应的类就会抛出ClassNotFoundException 。比如说:在CLASSPATH下有一个System类,当JAVA虚拟机加载时,AppClassLoader就会找到其父加载器ExtClassLoader,而ExtClassLoader又会找到它的父加载器BootStrap,这时BootStrap就会在jre/lib/rt.jar中去找System类,找到则加载到内存中,如果没有找到就地交给ExtClassLoader去加载,如果ExtClassLoader也没有找到就会交给AppClassLoader,如果还没有找到就抛出ClassNotFoundException。这里也得出一个结论,如果我们在CLASSPATH下自己写一个SYSTEM类是不会被类加载器加载的,因为BootStrap会首先加载jre/lib/rt.jar下的System类。当然我们也可以自己写一个类加载器来加载自己的类(可以用于实现对类的加密操作) 。