专栏首页帅小子的日常ClassLoader的工作机制

ClassLoader的工作机制

本文中主要介绍类加载器的工作机制

一:首先什么是类加载器?

  类加载器就是用来加载java类到java虚拟机中。java源程序经过编译之后形成字节码文件,类加载器将字节码文件加载到内存中,并转换成java.lang.Class的一个实例对象。

  JVM是基于栈操作的:所有的操作都要经过进栈和出栈操作。基于栈操作的优点:将运行时的优化工作和执行编译时优化的执行引擎相结合,从而起到优化Java字节码的目的。

二: 类加载器的作用:

  1. 将编译后的class字节码文件加载到JVM中。会在加载的过程进行审查每个类有哪个类加载器加载?加载哪个类?  实际上是存在一种父级优先的等级结构
  2. 将字节码文件重新解析成JVM统一要求的对象格式。

三:类加载器的分类

  •   BootStrap ClassLoader:加载的过程是由JVM自身决定的,具体如何加载,加载哪个类都是有JVM自身控制的,实际上他并不符合JVM规范,不存在等级结构,没有父加载  器,也没有子加载器。他仅仅是作为一个加载工具存在
  •      ExtClassLoader:虽然他本身是JVM的一部分,但是加载并不是有JVM自身加载,他服务的特定目标是在System.getProperties("java.ext.dirs")目录下
  •      APPClassLoader :是ExtClassLoader类加载器的子类,主要加载位于classpath目录下的类 System.getProperties("java.class.path")

四:JVM加载字节码文件的两种方式

  1. 隐式加载:不调用类加载器,将需要的类自动加载到内存中 例如:当前类需要外部类的引用时,就会触发隐式加载
  2. 显式加载:调用 this.getClass(),this.getClassLoader(),Class.forName(class)等方式完成的加载就是显式加载

两种加载方式可以混合使用,显式加载自定义的类,如果该类中有其他类的引用,就会触发隐式加载。

 五:类加载常见的错误分析

  • ClassNotFoundException:显式加载字节码文件时,找不到对应的字节码文件异常,发生这种问题的原因是在对应的classpath下可能没有对应的字节码文件,导致异常的发生;解决方案:到对应的classpath下面检查是否有对应的字节码文件,通过this.getClass().getClassLoader().getResources().toString();获得path的路径
  • NotClassDefFoundError:类不存在异常 产生的原因是:new关键字,引用类,继承接口或者类,方法参数用有引用,这些都会导致此种异常的发生。在隐式加载这些类时可能出现类不存在的异常。
  • ClassCastException:强制类型转换时出现这个错误   

  在JVM进行类型转换时会进行自动检查  

  1.   普通对象:必须是目标类的实例对象或者子类对象;如果是接口,对象是该接口的子类对象
  2.       数组对象:目标类必须是数组类型或者java.lang包下的Object ,Clonable,java.io包下的Serializable

  解决类型转换异常的方法:显式指明对象类型;通过instanceof判断是否是目标对象类型,然后在进行类型转换。

六:JVM的体系结构以及工作方式

  • JVM是通过模拟真实计算机,从而达到一个真实计算机所具有的计算功能的体系结构。以计算机为中心的真实计算机的体系结构
    •   指令集:计算机能够识别的机器语言的所有命令集合
    •        计算单元:能够识别并且控制指令执行的功能模块
    •        寄存器:中央处理器的核心组件,用来暂存,指令,地址和数据
    •        存储单元:能够存储计算机操作数和操作结构的单元,例如:内存和磁盘
    •        寻址方式:地址的范围,最小地址和最大地址范围以及地址的运行规则
  •   JVM的体系结构:
    •    执行引擎:相当于CPU,控制指令执行。解析字节码文件,得到解析结果。
    •         pc寄存器:每个线程启动的时候都会创建一个pc寄存器。寄存器中保存的是当前执行的JVM指令的地址。保存下一条将要执行的指令地址的寄存器是:pc寄存器。他总是保存着下一条将要执行的指令地址。地址可以是一个本地指针,也可以是方法中相对于方法起始指令的地址。
    •         本地方法栈:保存native方法的区域
    •         堆:保存的是创建的对象实例。所有的类对象都是通过new创建,创建对象后会在栈中创建该对象的引用。
    •         方法区:又叫做静态区:保存的是方法数据,类,静态变量,静态方法,常量和成员方法
    •         运行时常量池:存放的是类和接口的常量,除此之外,还有成员方法和成员变量的引用。JVM运行时就是通过这些引用来找到实际的地址

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • ClassLoader的工作机制

    用户2146856
  • spirng底层实现原理

    用户2146856
  • spring的事务配置方法

    用户2146856
  • ClassLoader的工作机制

    用户2146856
  • Java 类加载机制详解

    Java 虚拟机一般使用 Java 类的流程为:首先将开发者编写的 Java 源代码(.java文件)编译成 Java 字节码(.class文件),然后类加载器...

    哲洛不闹
  • 深入理解Java类加载机制

    其中解析过程在某些情况下可以在初始化阶段之后再开始,这是为了支持 Java 的动态绑定。

    李红
  • Javaweb-类加载器-类加载器的了解入门

    前面的动态代理学完了,以后在学习Spring的时候会用到这些动态代理的知识和原理,像目标对象,增强这两个术语,会经常听到。学习动态代理,就是学习JDK中反射包下...

    凯哥Java
  • java 类的加载

    加载是将class文件加载到 jvm内存,并为之创建一个大的Class,任何类被系统使用都会建立一个大Class对象。Class用来表示文件内容,成员变量,构...

    用户7625070
  • java类加载机制,再也不怕面试官的刁难

    上一篇我们详细的讲解了java 虚拟机的内存模型(),并且知道了我们写的代码分别是怎么存在JVM的哪个内存区域中。今天我们来看另一个重要的问题,类加载机制的核心...

    架构师修炼
  • 连 JVM 类加载机制都扯不清楚,还想成为架构师?

    类加载器把class文件中的二进制数据读入到内存中,存放在方法区,然后在堆区创建一个java.lang.Class对象,用来封装类在方法区内的数据结构。

    本人秃顶程序员

扫码关注云+社区

领取腾讯云代金券