`

如何实现自己的classloader

    博客分类:
  • java
阅读更多

如何实现自己的classloader

如何实现自己的classloader来加载类      刚开始学习加载的时候,接触到的是HeloWorld程序,当时不知道为什么在public static void main(String [] args) 方法里写了System.out.println("Hello World!") 就可以在控制台打出“Hello World!”来,确实的说,是什么东西隐蔽在后面执行了我们写的这段代码,通过后来的学习,知道了所有的class都是通过classloader来加载的。java规范这么说,Java的ClassLoader就是用来动态装载class的,ClassLoader对一个class只会装载一次,JVM使用的ClassLoader一共有4种:
          启动类装载器,标准扩展类装载器,类路径装载器和网络类装载器。
这4种ClassLoader的优先级依次从高到低,使用所谓的“双亲委派模型”。确切地说,如果一个网络类装载器被请求装载一个java.lang.Integer,它会首先把请求发送给上一级的类路径装载器,如果返回已装载,则网络类装载器将不会装载这个java.lang.Integer,如果上一级的类路径装载器返回未装载,它才会装载java.lang.Integer。

        再说说Package权限。Java语言规定,在同一个包中的class,如果没有修饰符,默认为Package权限,包内的class都可以访问。但是这还不够准确。确切的说,只有由同一个ClassLoader装载的class才具有以上的Package权限。比如启动类装载器装载了java.lang.String,类路径装载器装载了我们自己写的java.lang.Test,它们不能互相访问对方具有Package权限的方法。这样就阻止了恶意代码访问核心类的Package权限方法。     
        现在来通过扩展ClassLoader类实现一个自己的类装载器,每个Class对象都有一个引用指向装载他的ClassLoader,可以通过public ClassLoader getClassLoader()方法得到它。为了创建自己的类装载器我们应该扩展ClassLoader类,这是一个抽象类。假设要从本地文件系统使用我们实现的类装载器装载一个类,创建一个FileClassLoader extends ClassLoader,需要覆盖ClassLoader中的findClass(String name)方法,这个方法通过类的名字而得到一个Class对象。

package test.International;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
public class FileClassLoader extends ClassLoader{
    
public static final String drive = "d:/";
    
public static final String fileType = ".class";
    
public FileClassLoader() {
         super();
     }

    
public FileClassLoader(ClassLoader arg0) {
         super(arg0);
     }

    
public Class findClass(String name) {
        
byte[] data = loadClassData(name);
        
return defineClass(name, data, 0, data.length);
     }

    
public byte[] loadClassData(String name) {
         FileInputStream fis
= null;
        
byte[] data = null;
        
try {
             fis
= new FileInputStream(new File(drive + name + fileType));
             ByteArrayOutputStream baos
= new ByteArrayOutputStream();
            
int ch = 0;
            
while ((ch = fis.read()) != -1) {
                 baos.write(ch);
             }

             data
= baos.toByteArray();
         }
catch (IOException e) {
             e.printStackTrace();
         }

        
return data;
     }

    
public static void main(String[] args) throws Exception {
         FileClassLoader loader
= new FileClassLoader();
         Class objClass
= loader.loadClass("HelloWorld", true);
         Object obj
= objClass.newInstance();
         System.
out.println(objClass.getName());
         System.
out.println(objClass.getClassLoader());
     }

}

现在把HelloWorld.java放到默认包下,然后编译,把HelloWorld.class放到D:\盘根目录下,运行FileClassLoader类,控制台输出:

HelloWorld
sun.misc.Launcher$AppClassLoader@82ba41

可见,我们的确加载上了HelloWorld.class

分享到:
评论
1 楼 sotrip 2012-10-05  
从上面结果来看,HelloWorld.class是由虚拟机的内置装载器加载的(sun.misc.Launcher$AppClassLoader@82ba41),

不是我们的FileClassLoader加载的

要把HelloWorld.class放在ClassPath之外,这样虚拟机的内置装载器就装载不了了,就可以通过我们的FileClassLoader来加载

相关推荐

    ClassLoader运行机制 自己写的

    在Java虚拟机(JVM)中,类加载器(ClassLoader)是至关重要的组成部分,它负责查找和加载类...在编写自己的ClassLoader时,需要考虑如何正确实现加载逻辑,以及如何处理类加载的并发问题,确保应用的稳定性和安全性。

    自定义classloader的使用

    在`findClass`中,我们可以实现自己的类查找策略,而在`loadClass`中,我们需要调用`defineClass`方法将字节码转换为Class对象。 三、自定义加载路径 默认情况下,Classloader从JAR文件或当前目录(CLASSPATH)...

    classloader

    2. 创建自定义ClassLoader:掌握如何编写自己的ClassLoader子类,实现自定义的加载策略。 3. 整合自定义ClassLoader:了解如何将自定义的ClassLoader集成到Java应用程序中,替换或扩展默认的加载行为。 4. 考虑Java ...

    Java ClassLoader定制实例

    这个模型的工作原理是:当一个ClassLoader接收到类加载请求时,它首先不会自己去加载,而是委托给父ClassLoader去尝试加载,只有当父ClassLoader无法加载时,子ClassLoader才会尝试自己去加载。这样做保证了类的唯一...

    classloader的简单实现

    在Java编程语言中,类加载器(ClassLoader)是一个至关重要的组件,负责将类的字节码从...通过对"my_classloader"项目的探索,我们可以深入学习类加载器的实现原理,这对于理解和扩展自定义的类加载器系统至关重要。

    ClassLoader

    ### Java虚拟机中ClassLoader概述与双亲委托机制详解 #### 一、ClassLoader概念与作用 在Java编程语言中,`ClassLoader`是一个非常重要的组件,它负责加载程序运行所需的类文件到Java虚拟机(JVM)中。`ClassLoader`...

    ClassLoader小例子

    在Java编程语言中,ClassLoader是一个至关重要的组成部分,它负责加载类到JVM(Java虚拟机)中,使得...通过深入研究"ClassLoader小例子",你可以更好地理解Java的类加载机制,并为自己的项目开发带来更多的灵活性。

    ClassLoader 案例

    自定义ClassLoader则允许我们插入这个流程,按照自己的规则去查找和加载类。 在自定义ClassLoader时,主要需要覆写两个关键方法:`findClass()` 和 `loadClass()`。`loadClass()` 方法通常用于委托父类加载器加载类...

    java ClassLoader机制及其在OSGi中的应用

    1. 每个OSGi bundle都有自己的ClassLoader,用于加载该bundle中的类,这使得不同bundle之间的类隔离得以实现,避免了类冲突。 2. OSGi的ClassLoader支持动态加载和卸载bundle,当bundle被激活或停用时,对应的类...

    JVM ClassLoader简析

    ClassLoader还有自定义的概念,允许开发者创建自己的ClassLoader来实现特定的加载逻辑。例如,从网络、数据库或特定文件系统加载类。这在动态加载类、插件系统或者模块化应用中非常有用。 在"Sample.zip"文件中,...

    ClassLoader 详解.doc

    自定义ClassLoader是Java平台的一大特色,开发人员可以根据需要创建自己的类加载器,例如实现模块化、热部署或者加密解密类等高级功能。自定义ClassLoader通常需要重写findClass()或loadClass()方法,以控制类的加载...

    深入理解ClassLoader工作机制.docx

    这个过程可以通过自定义ClassLoader来实现,比如从数据库中加载类。 2. **验证**:验证是确保加载的类符合Java语言规范,不会破坏JVM的安全性。它检查字节码的格式、数据流和操作符计算、类和字段的访问控制等。 3...

    ClassLoader的 一些测试

    4. 类隔离:通过自定义ClassLoader实现不同模块之间的类隔离,避免类冲突。 总的来说,深入理解ClassLoader的工作原理对于优化程序性能、构建灵活的插件系统和解决类冲突问题具有重要意义。通过测试和实践,我们...

    理解Java ClassLoader机制

    理解ClassLoader的工作原理对于优化应用性能、处理类加载问题以及实现自定义加载器至关重要。 首先,我们来了解一下ClassLoader的基本层次结构。在Java中,ClassLoader分为三个主要层次:Bootstrap ClassLoader、...

    ClassLoader类加载机制和原理详解

    开发者可以通过继承java.lang.ClassLoader类,创建自己的类加载器。这在处理动态加载、插件系统、隔离应用域等场景时非常有用。自定义类加载器需要覆盖`findClass()`方法,实现类的查找和加载逻辑。 4. 双亲委派...

    java classloader

    深入类别载入器.pdf`直接指向ClassLoader的深入讨论,可能包括自定义ClassLoader的实现、双亲委派模型等主题。`CH_05.package与import机制.pdf`可能讲解了与ClassLoader相关的包和导入机制,因为它们与类的组织和...

    ClassLoader原理

    ClassLoader的扩展性体现在,我们可以通过继承ClassLoader并重写其方法,实现自己的类加载策略。例如,我们可以创建一个网络ClassLoader,从远程服务器动态加载类,实现按需加载,减少内存占用。 总的来说,理解...

Global site tag (gtag.js) - Google Analytics