一、类加载器(ClassLoader)
把java类的数据从Class文件中加载到虚拟机内容中,然后对这部分数据进行验证、准备、解析、初始化,最终转换成对应的可以被jvm使用java.lang.Class
对象实例。
类加载器的一些方法:
- getParent()
返回该类加载器的父类加载器;
- loadClass(name:String)
加载名称为name的类;
- findClass(name:String)
查找名称为name的类;
- findLoaderClass(name:String)
查找名称为name的已经加载过的类
- defineClass(name:String, b:ByteArray?, off:Int, len:Int)
把字节数组b的内容转化成java类,返回的结果是java.lang.class类的实例。这个方法被声明为final的
二、类加载的分类
- Bootstrap Loader(启动类加载器)
用c++编写,是jvm自身的一部分,主要负责加载java的核心类;
- Extended Loader(扩展类加载器)
Extended Loader的父加载器为Bootstrap Loader,用java编写,主要负责加载java的扩展库;
- AppClass Loader(系统类加载器)
AppClass Loader的父加载为Extended Loader,用java编写,主要负责加载java应用的类路经(classpath)上的类库;
三、类加载过程
寻找jre目录,寻找jvm.dll,并初始化jvm,jvm启动后,运行Bootstrap Loader,Bootstrap Loader(启动类加载器)自动加载Extended Loader(扩展类加载器)和AppClass Loader(系统类加载器),最后AppClass Loader加载classpath目录下定义的class。
四、双亲委派模型
如果一个类加载器收到类加载的请求,它首先不会尝试去加载这个类,而是把请求委托给父加载器去完成,依次向上,因此,所有的类加载请求最终都应该被传递到顶层的启动类加载器中,只有当父加载器在它的搜索范围内没找到所需的类时,即无法完成该加载,子加载器才能尝试去加载该类。
代码实现
双亲委派模开支有什么作用?
五、类加载的三种方式
六、案例分析