1.JVM支持两种类加载器,一种是引导类加载器(用C和C++语言写的),另外一种是自定义加载器)(用java语言写的)
除引导类加载器以后,其他的类加载器都叫自定义加载器,扩展类ExtClassLoad加载器和系统类加载器AppClassLoad也是自定义加载器。
2.
ClassLoader systemClassLoader = ClassLoader.getSystemClassLoader();
// 获取系统类加载器
System.out.println(systemClassLoader);
ClassLoader parent = systemClassLoader.getParent();
// 获取扩展类加载器
System.out.println(parent);
ClassLoader parent1 = parent.getParent();
// 再获取的话,返回的就是null
System.out.println(parent1);
3.如果是用户自定义的类加载器:
public class StackStructTest extends ClassLoader{
public static void main(String[] args) {
ClassLoader classLoader = StackStructTest.class.getClassLoader();
System.out.println(classLoader);
}
}
sun.misc.Launcher$AppClassLoader@b4aac2
如果是String的话,它的类加载是谁呢?
public static void main(String[] args) {
ClassLoader classLoader = String.class.getClassLoader();
System.out.println(classLoader);
}
输出:
null
因为String是引导类加载器加载的,是用C和C++写的,所以我们获取不到它的类加载器。
JAVA的核心类都是引导类加载器加载的。
启动类加载器负责加载java javac sun等开头的类
如果我们把字节码放在扩展类加载器加载的目录下,也会被扩展类加载器加载,因为扩展类加载器是根据路径去加载的
用户自定义加载器:
1 隔离加载类(项目引用了很多框架,框架在设计的时候,避免类冲突)
修改类的加载方式
扩展加载源
防止源码泄露( 对字节码进行加密,在环境中,再对字节码文件进行解密操作)