读完App Class Loader的体会

Some thoughts on App Class Loader
【本文的主要参考文章AppClassLoader的作者是大名鼎鼎的java视线老大robbin 】

我没看过java深度历险,但也多少听过一些关于class loader的讨论,看过robbin兄写的App Class Loader文章深有体会,在此用自己的话稍微总结归纳一下。

一个Java系统的运作过程允许了不同JVM Class loader的同时存在,了解不同loader之间的关系非常关键,如下图

App Class Loader
|----- EJB Class Loader
|----- Web App Class Loader

App Class Loader级别是全局可见,而它属下的两个loader只是局部有效互不干扰。

App Class Loader的loading顺序为JRE/lib/* => JRE/lib/ext/* => JRE/classes/* => CLASSPATH/*

Web App Class Loader的loading范围在WEB-INF/lib/*和WEB-INF/classes/*
它们会在loading范围开始寻找并调入所需要的Class/Jar/Lib,如果失败,才把loading责任上交给App Class Loader,这就是所谓的Class Loader继承关系

EJB Class Loader的loading范围仅限于JAR或者EAR范围之内。App Server会针对每一个EJB包文件创建一个EJB Class Loader的实例,例如:当你发布Hello.jar, World.jar两个jar后,系统会创建两个EJB Class Loader的实例,分别去load这两个EJB包,所以Hello.jar根本看不到除它自己以外的任何文件。另外如果要调用jar包之外的类库的名称,需要在jar包的manifest文件中定义Class-Path: log4j.jar hibernate2.jar

这篇文章解释了大家或许有点陌生的Class Loader也有层次继承关系,the visability of usable classes/jars is defined by the class loader and all its ancestors. 这个概念在j2ee中很重要,需要好好理解。

你可能感兴趣的:(J2EE学习实践,class,ejb,hibernate,jar,java,server)