java的类加载机制java的类加载器ClassLoader是一个抽象类,主要是用于将.class文件加载到JVM内存中,并转换成JVM可以识别的Class对象。ClassLoader类结构分析:      经常会用或扩展ClassLoader的几个方法及其重载方法有:      1). Class>   defineClass(byte[], int, int)             用来将byte字节流解析成JVM能够识别的Class对象,一般和findClass方法一起使用,通过直接覆盖ClassLoader父类的findClass方法来实现类的加载规则,从而取得加载类的字节码,再通过defineClass方法获取类的Class对象.在运行时能加载自己指定的类,可以用下面的方法获取:     this.getClass().getClassLoader().loadClass("com.ran.test2.Test");     com.ran.test2.Test为含包名的类名      2). Class>   findClass(String)            实现类的加载规则,从而取得加载类的字节码        3). Class>   loadClass(String)           获取指定类的Class对象      4). void   resolveClass(Class>)           在对象真正实例化时才调用

ClassLoader的等级加载机制:加载机制:双亲委派机制双亲委派机制的过程是:一个类加载器收到类加载的请求时,会先请示父类加载器进行加载,如果父类加载器找不到(在其搜索范围内没有找到),那么才会由该类加载器自己进行加载。

从java虚拟机角度讲,只存在两种不同的类加载器:启动类加载器(BootStrap ClassLoader):使用C++实现,是虚拟机自身一部分;其他类加载器:使用Java实现,独立于虚拟机外部,都继承抽象类ClassLoader;

从Java开发角度讲,可分为下面三种不同的加载器: 启动类加载器(BootStrap ClassLoader): 主要加载JVM自身需要的类(JavaHome的lib目录中且是虚拟机识别的类库,如rt.jar),只是一个类加载工具,没有父加载器和子加载器; 扩展类加载器(ExtClassLoader):主要负责加载JavaHome的lib/ext目录中和java.ext.dirs系统变量指定路径中的类库; 应用程序类加载器(AppClassLoader):主要负责加载用户路径上(ClassPath)所指定的类库;

JVM加载class文件到内存有两种方式:1).隐式加载:不通过在代码中调用ClassLoader来加载需要的类,而是通过JVM来自动加载需要的类到内存。2).显示加载:在代码中通过调用ClassLoader来加载一个类的方式,如: 如:this.getClass().getClassLoader().loadClass("com.ran.test2.Test"),Class.forName("com.ran.test2.Test")或者自己实现ClassLoader的findClass()方法

Class文件的加载过程: 类加载的全过程包括五个阶段:加载、验证、准备、解析、初始化,其中验证、准备、解析三个过程称为连接。

加载:找到.class文件并把文件包含的字节码加载到内存中验证:确保class文件的字节流中包含的信息符合虚拟机的要求,主要包含四个检验过程:文件格式严验证、元数据验证、字节码验证、符号引用验证。准备:为类变量(static修饰的变量)分配内存并设置初始值(此时虽然有初始值,但不执行java代码,不进行初始化),默认基本类型初始值为0,引用类型为null。解析:将常量池中的符号引用替换为直接引用,主要针对类或接口、字段、类方法、接口方法四类的符号引用的解析。初始化:类第一次被使用时,才会初始化;主要是执行类构造器()方法,执行类变量的赋值操作和静态代码块。初始化发生的时机:       new关键字实例化对象;       调用类的静态方法:       给类的静态域赋值;      使用反射调用时,如果类没初始化,需要先触发其初始化; 初始化一个类时,如果父类没有初始化,则需先触发其父类的初始化; 虚拟机启动时,用户指定执行的主类,虚拟机需要初始化这个主类。

破坏双亲委派:第一次破坏:发生在双亲委派模型出现之前--即JDK1.2之前。JDK1.2之前,用户自定义类加载器是继承ClassLoader重写loadClass()方法,因为虚拟机在进行类加载时会调用加载器的私有方法loadClassInternal(),而这个方法的唯一逻辑是调用自己的loadClass()方法。JDK1.2之后,不提倡用户再去覆盖loadClass()方法,而是把自己的类加载逻辑写到findClass()逻辑中。第二次破坏:模型自身缺陷导致。JNDI服务采用线程上下文类加载器去加载所需要的SPI代码,也就是父类加载器采用子类加载器去完成类加载的动作,java中所有涉及SPI的加载动作基本都是采用这种方式,例如JNDI、JDBC、JCE、JAXB和JBI等。第三次破坏:用户对程序动态性的追求而导致的。在OSGi环境下,类加载器不再是双亲委派中的树状结构,而是进一步发展为网状结构。

自定义ClassLoader:

packagecom.ran.test02;public classTest01{

publicTest01() {

System.out.println("This is Test01");}

}packagecom.ran.test02;importjava.io.*;public classPathClassLoaderextendsClassLoader{

privateStringclassPath;privateStringpackageName= "com.ran.classpath";publicPathClassLoader(StringclassPath){

this.classPath= classPath;}

protectedClass> findClass(Stringname) throwsClassNotFoundException{

if(name.startsWith(packageName)){

byte[] classData = getData(name);if(classData == null){

throw newClassNotFoundException();} else{

returndefineClass(name,classData,0,classData.length);}

} else{

return super.loadClass(name);}

}

private byte[] getData(StringclassName) {

Stringpath = classPath+ File.separatorChar+ className.replace('.',File.separatorChar) + ".class";try{

InputStreamis = newFileInputStream(path);ByteArrayOutputStreambaos = newByteArrayOutputStream();byte[] buffer = new byte[2048];intnum = 0;while((num = is.read(buffer)) != -1){

baos.write(buffer,0,num);}

returnbaos.toByteArray();} catch(IOExceptione){

e.printStackTrace();}

return null;}

public static voidmain(String[] args) throwsException{

Stringpath = ClassLoader.getSystemResource("").getPath().substring(1);PathClassLoaderloader = newPathClassLoader(path);System.out.println(loader.findClass("com.ran.test02.Test01").newInstance());}

}

本文参考《深入理解虚拟机》

更多相关知识,可参考http://www.hollischuang.com/archives/201

http://www.hollischuang.com/archives/199

java破坏双亲委派_java的类加载机制-双亲委派,破坏双亲委派相关推荐

  1. 深入理解java虚拟机 第7章 虚拟机类加载机制

    目录 7.1 概述 7.2 类加载的时机 类加载生命周期 开始顺序 类初始化时机 主动引用 被动引用 接口加载与类加载过程的区别 7.3 类加载的过程 7.3.1 加载 7.3.2 验证 7.3.3 ...

  2. java类加载机制为什么双亲委派_[五]类加载机制双亲委派机制 底层代码实现原理 源码分析 java类加载双亲委派机制是如何实现的...

    Launcher启动类 本文是双亲委派机制的源码分析部分,类加载机制中的双亲委派模型对于jvm的稳定运行是非常重要的不过源码其实比较简单,接下来简单介绍一下我们先从启动类说起有一个Launcher类 ...

  3. Java 工程师必须掌握的 JVM 类加载机制!

    这篇文章不聊别的,专门来侃侃JVM的类加载机制 概念 类加载器把class文件中的二进制数据读入到内存中,存放在方法区,然后在堆区创建一个java.lang.Class对象,用来封装类在方法区内的数据 ...

  4. java虚拟机类加载机制浅谈_浅谈Java虚拟机(三)之类加载机制

    在<浅谈Java虚拟机>这篇文章中,我们提到了JVM从操作系统方面来说,可以将其看做是一个进程,分别有类加载器子系统,执行引擎子系统和垃圾收集子系统.这一篇文章就简单的来谈一下类加载器子系 ...

  5. java虚拟机类加载机制_《深入理解java虚拟机》学习笔记一/类加载机制

    为何要读这本书? 近期看了左萧龙大哥的单例设计模式,后文讲解到了JVM对类实例化相关知识,感觉看着很无力,不懂,于是乎买本书研究下. 如何读? 个人水平一般,理解程度有限,书中说到每章关联不是很大,所 ...

  6. java 判断object类型_Java 类继承机制

    封装.继承.多态是面向对象的三大特征,"继承"最主要的目的是为了实现代码的可复用性.通过父类与子类的继承关系,子类继承了父类的成员函数和成员变量,提高了代码的重复利用率.同时,子类 ...

  7. [疯狂Java讲义精粹] 第十三章|类加载机制与反射

    java.lang.reflect包下的接口和类, 包括Class, Method, Filed,Constructor和Array等, 这些类分别代表类, 方法, Field, 构造器和数组, Ja ...

  8. 无招胜有招之Java进阶JVM(八)类加载机制

    6.1.ClassLoader的两个作用和一个任务 作用:1.将Class加载到JVM中2.审视每一个类应该由谁加载. 任务:将Class字节码重新解析成统一要求的对象格式 6.2上级委托接待机制又称 ...

  9. java 虚拟机内存类_java 虚拟机类加载 及内存结构

    在面试java工程师的时候,这道题经常被问到,故需特别注意. 1.JVM 简介 JVM 是我们Javaer 的最基本功底了,刚开始学Java 的时候,一般都是从"Hello World &q ...

  10. java 强制垃圾回收_Java垃圾回收机制

    Java垃圾回收机制 垃圾回收机制用到finalize.当程序创建对象.数组等引用类型实体时,系统都会在堆内存中为之分配一块内存区,对象就保存在这块内存中,当这块内存不再被任何引用变量引用时,这块内存 ...

最新文章

  1. windows优化大师8周年纪念版_《数码宝贝》20周年纪念:当年的八神太一与亚古兽你还记得吗?...
  2. 算法----选择排序(select sort)
  3. malloc和new有什么区别
  4. Inside Dynamics Axapta源代码赏析(四)
  5. 女生学计算机未来出路,计算机真的已经烂大街了吗,女生学计算机没出路吗?...
  6. 利用Python分析羊车门问题
  7. excel通过转成xml格式模板,下载成excel文件
  8. 《Tomcat权威指南》读书笔记
  9. LeetCode(15)3Sum
  10. 基于逻辑回归的标准评分卡实现
  11. python collections模块_python collections模块
  12. 解决百度文库复制问题 非VIP也能复制文字
  13. 【第52期】游戏策划:应聘的误区你信了几个?
  14. 税控盘系统参数设置服务器,税控盘设置服务器地址
  15. spss可以关键词词频分析吗_有什么自动分词做词频分析的工具?
  16. 第五章 区块链怎么玩 [25]
  17. 洛谷(Python) P3717 [AHOI2017初中组]cover
  18. matlab实现图像处理教程,Matlab图像处理入门教程(菜鸟级)
  19. 计算机从外部世界接收信息和向外部世界反馈运算结果的手段
  20. topcoder使用介绍

热门文章

  1. Recover through incarnations: RMAN-20208
  2. 安装autocad2006出错
  3. 投简历:求求你给我个机会「小废物招聘全记录①」
  4. 3.jenkins 基础
  5. 7.2.Zeng_Cache(3) --- 前端
  6. php中的exception与自定义异常类
  7. html中表格table的内容居中显示
  8. Set和Map的区别 (@es6)
  9. Java并发编程之volatile关键字解析
  10. 数据库和Content Provider