类加载器就是用来加载类的对象,而ClassLoader是一个抽象类,只要给出类的二进制名称,类加载器就能确定或生成构建这个类的定义;通常是把二进制名称转成文件系统的文件名,再读入这个类文件。
每个类对象都拥有getClassLoader 这个方法;
数组创建的类对象不是由类加载器加载的,而是运行时按需加载,对每一个数组元素调用类加载器,而元素类型为原始类型时就没有类加载器;
可以通过继承ClassLoader来扩展一些在JVM动态加载过程中的处理方式
类加载器常用于安全管理,指明哪些是安全域
ClassLoader使用一种委托模式来查找类和资源,每个ClassLoader的实例都有自己的父类加载器,当自己要查找类或资源前,ClassLoader先委托父类进行查找 。
虚拟机有一个内置的类加载器,bootstrap class loader,它没有父类加载器,却可以当其它类加载器的父类加载器。
类加载器支持并行加载,即所谓的并发模式,这个需要类加载在初始化阶段调用registerAsParallelCapable 自己注册;ClassLoader是默认并行的,而它的子类需要主动注册。
当执行环境中的代理模式层次不清时,类加载需要并行加载,因为类加载进程方法会持有加载锁,这可能导致死锁。
通常JVM加载都使用平台依赖的方式从本地加载类,例如UNIX系统,虚拟机是从CLASSPATH环境变量定义的路径开始加载类;
然后还有些类是从网络生成的,
网络类加载器的子类必须有以下2个方法,
class NetworkClassLoader extends ClassLoader {
String host;
int port;
public Class findClass(String name) {
byte[] b = loadClassData(name);
return defineClass(name, b, 0, b.length);
}
private byte[] loadClassData(String name) {
// load the class data from the connection
}
原文:https://www.cnblogs.com/iamgoodman/p/10164025.html