jvm自带的三个classloader
1.Bootstrap classloader,是jvm的一部分,由C写成,调用的是核心库。
sun java下,可以用以下语句查看调用类路径
URL[] urls = sun.misc.Launcher.getBootstrapClassPath().getURLs();
写道
%JAVA_HOME%/jre/lib/resources.jar
%JAVA_HOME%/jre/lib/rt.jar
%JAVA_HOME%/jre/lib/sunrsasign.jar
%JAVA_HOME%/jre/lib/jsse.jar
%JAVA_HOME%/jre/lib/jce.jar
%JAVA_HOME%/jre/lib/charsets.jar
%JAVA_HOME%/jre/lib/jfr.jar
%JAVA_HOME%/jre/classes
%JAVA_HOME%/jre/lib/rt.jar
%JAVA_HOME%/jre/lib/sunrsasign.jar
%JAVA_HOME%/jre/lib/jsse.jar
%JAVA_HOME%/jre/lib/jce.jar
%JAVA_HOME%/jre/lib/charsets.jar
%JAVA_HOME%/jre/lib/jfr.jar
%JAVA_HOME%/jre/classes
2.ExtClassLoader,调用系统扩展类
写道
%JAVA_HOME%/jre/lib/ext/access-bridge.jar
%JAVA_HOME%/jre/lib/ext/cldrdata.jar
%JAVA_HOME%/jre/lib/ext/dnsns.jar
%JAVA_HOME%/jre/lib/ext/jaccess.jar
%JAVA_HOME%/jre/lib/ext/jfxrt.jar
%JAVA_HOME%/jre/lib/ext/localedata.jar
%JAVA_HOME%/jre/lib/ext/nashorn.jar
%JAVA_HOME%/jre/lib/ext/sunec.jar
%JAVA_HOME%/jre/lib/ext/sunjce_provider.jar
%JAVA_HOME%/jre/lib/ext/sunmscapi.jar
%JAVA_HOME%/jre/lib/ext/sunpkcs11.jar
%JAVA_HOME%/jre/lib/ext/zipfs.jar
%JAVA_HOME%/jre/lib/ext/cldrdata.jar
%JAVA_HOME%/jre/lib/ext/dnsns.jar
%JAVA_HOME%/jre/lib/ext/jaccess.jar
%JAVA_HOME%/jre/lib/ext/jfxrt.jar
%JAVA_HOME%/jre/lib/ext/localedata.jar
%JAVA_HOME%/jre/lib/ext/nashorn.jar
%JAVA_HOME%/jre/lib/ext/sunec.jar
%JAVA_HOME%/jre/lib/ext/sunjce_provider.jar
%JAVA_HOME%/jre/lib/ext/sunmscapi.jar
%JAVA_HOME%/jre/lib/ext/sunpkcs11.jar
%JAVA_HOME%/jre/lib/ext/zipfs.jar
3.AppClassLoader,调用classpath里的类
这三个类遵循双亲委派模型,也就是先每装载一个类时,先从父装载器装载,找不到才一级级往下找,这也就是classpath里的类无法覆盖jdk里自带类的原因。
像tomcat等应用,涉及到webapp隔离,所以在装载每个webapp里的类时,没有遵循双亲委派模型,而是优先自己所调用的类,另外这里有个关键点,就是隐式装载,也就是用关键字new创建对象时,装载这个类所使用的装载器是使用new关键字所在类的装载器。
以下代码可以模拟这个过程。
自定义类装载器
package jp.co.wqf; import java.io.ByteArrayOutputStream; import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; public class MyClassLoader extends ClassLoader { private String name; private String path = "D:/"; private final String fileType = ".class"; public MyClassLoader(String name){ super(); this.name = name; } public MyClassLoader(String name, ClassLoader cl){ super(cl); this.name = name; } public String getPath() { return path; } public void setPath(String path) { this.path = path; } @Override protected Class<?> findClass(String name) throws ClassNotFoundException { byte[] data = loaderClassData(name); return this.defineClass(name, data, 0, data.length); } private byte[] loaderClassData(String className){ InputStream is = null; byte[] data = null; ByteArrayOutputStream baos = new ByteArrayOutputStream(); String fileName = className.replace(".", "/"); try { is = new FileInputStream(new File(path + fileName + fileType)); int c = 0; while(-1 != (c = is.read())){ baos.write(c); } data = baos.toByteArray(); } catch (Exception e) { e.printStackTrace(); } finally{ try { is.close(); baos.close(); } catch (IOException e) { e.printStackTrace(); } } return data; } }
测试
package jp.co.wqf; public class Test { public static void main(String[] args) { // TODO Auto-generated method stub MyClassLoader classLoader = new MyClassLoader("classload1"); classLoader.setPath("/eclipse/workspace/Test/bin/"); try { Class<?> clsA = classLoader.loadClass("jp.co.wqf.A"); Object objA = clsA.newInstance(); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (InstantiationException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IllegalAccessException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
以下类不要放在上面代码的classpath里
package jp.co.wqf; public class A { private B b; public A(){ this.b = new B(); } }
package jp.co.wqf; public class B { private C c; public B(){ this.c = new C(); } }
package jp.co.wqf; public class C { public C(){ System.out.println("create class c!"); } }
相关推荐
在Java编程语言中,`Classloader`(类加载器)是一个至关重要的组件,它负责将类的`.class`文件从磁盘加载到JVM(Java虚拟机)内存中,使得程序能够执行。这篇博文主要围绕`Classloader`的`loadClass`方法进行深入...
在Java虚拟机(JVM)中,类加载器(ClassLoader)是至关重要的组成部分,它负责查找和加载类的字节码文件。理解ClassLoader的工作机制对于深入掌握Java应用程序的运行至关重要。这里我们将详细讨论ClassLoader的运行...
Java ClassLoader是Java运行时系统的关键但经常被忽视的组件,负责在运行时查找和加载类文件。通过创建自定义ClassLoader,你可以定制JVM,使类文件的引入方式完全重新定义,这提供了很多实用和有趣的可能。这篇教程...
### Java虚拟机中ClassLoader概述与双亲委托机制详解 #### 一、ClassLoader概念与作用 在Java编程语言中,`ClassLoader`是一个非常重要的组件,它负责加载程序运行所需的类文件到Java虚拟机(JVM)中。`ClassLoader`...
在本教程中,我们将深入探讨Java编程语言中的两个核心概念:动态代理和Java 8的新特性,特别是关于ClassLoader的部分。动态代理是Java中一个强大的工具,它允许在运行时创建对象,这些对象可以作为其他对象的代理,...
在Java中,Classloader是加载类的关键组件,它负责查找、加载和初始化字节码文件。自定义Classloader允许开发者根据特定需求定制类的加载逻辑,例如加密类文件、隔离不同版本的库或者动态加载代码。本文将深入探讨...
在Java编程语言中,ClassLoader是一个至关重要的组成部分,它负责加载类到JVM(Java虚拟机)中。理解ClassLoader的工作原理以及如何定制它,对于深入学习Java的运行机制和进行高级应用开发具有重要意义。本篇文章将...
在Java编程语言中,ClassLoader是一个至关重要的组成部分,它负责加载类到JVM(Java虚拟机)中,使得程序能够执行。本示例"ClassLoader小例子"将深入探讨这个概念,并通过一个具体的程序来演示其工作原理。下面我们...
Java ClassLoader机制是Java虚拟机(JVM)中一个至关重要的组成部分,它的主要任务是将类的.class文件加载到JVM中,使得程序能够运行。ClassLoader不仅负责类的加载,还涉及类的验证、初始化等一系列过程。理解...
《深入理解ClassLoader工作机制》 Java虚拟机(JVM)中的ClassLoader是负责加载类到内存中的核心组件。它不仅承担着将字节码转换为可执行对象的重任,还参与了类生命周期的各个阶段,包括加载、验证、准备、解析、...
首先,ClassLoader可以分为三种基本类型:Bootstrap ClassLoader、Extension ClassLoader和Application ClassLoader。Bootstrap ClassLoader是JVM启动时的第一个ClassLoader,负责加载JDK的`<JAVA_HOME>\lib`目录下...
通过这些文档,你可以获得关于Java ClassLoader的全面理解,包括它的作用、工作流程、如何自定义以及它在整个Java生态系统中的位置。学习这些知识对于提升你的Java编程技能,尤其是开发复杂和动态的应用程序时,是...
《ClassLoader详解》 Java应用程序的运行离不开类的加载,而ClassLoader正是这个过程的关键角色。它负责将类的字节码加载到Java虚拟机(JVM)中并转换为可执行的Java对象。深入理解ClassLoader的工作原理对于优化...
Java ClassLoader机制是Java运行时环境中的核心组件之一,它负责加载类到JVM(Java虚拟机)中,使得程序能够执行。理解ClassLoader的工作原理对于优化应用性能、处理类加载问题以及实现自定义加载器至关重要。 首先...
破解java加密的ClassLoader.java,在classloader植入破解代码
在Java编程语言中,ClassLoader是核心组件之一,它负责加载类到JVM(Java虚拟机)中。自定义ClassLoader允许开发者根据特定需求加载类,比如动态加载或更新类文件,这在某些高级应用场景中非常有用,如插件系统、热...
在Java编程语言中,ClassLoader是核心组件之一,它负责加载类到JVM(Java虚拟机)中执行。本文将深入探讨ClassLoader的工作原理和类加载机制,帮助开发者理解这个至关重要的概念。 1. 类加载机制概述 Java的类加载...
在Java编程语言中,ClassLoader是一个至关重要的组成部分,它负责加载类到JVM(Java虚拟机)中执行。这篇测试主要探讨了ClassLoader的工作原理及其在实际应用中的使用。通过阅读给出的博文链接,我们可以深入理解...