博客
关于我
JVM类加载器详解
阅读量:765 次
发布时间:2019-03-23

本文共 2985 字,大约阅读时间需要 9 分钟。

Java Class Loading Mechanism Explained

The Java class loading mechanism is a cornerstone of the Java Virtual Machine (JVM) that ensures applications run correctly by dynamically loading classes into memory. This process is managed by the ClassLoader class, which acts as a bridge between the external class files and the JVM's runtime environment.

The Class Loader Phases

The class loader operates through three main phases, each ensuring that classes are loaded, linked, and initialized correctly.

  • Loading Phase (Verification and Preparing)

    • Verification: The class loader reads the byte code from the file and checks it against the JVM specification to ensure it conforms to the expected structure. This prevents the loading of invalid or malformed class files.
    • Preparation: The class loader initializes the static variables and assigns default values to instance variables. This is done by the Class inappropriate class.
  • Linking Phase (Validation and Resolution)

    • Validation: The class loader cross-verifies the dynamic variables and ensures static fields are correctly resolved.
    • Resolution: The class loader converts symbolic references in the class file into direct references within the JVM. This is necessary for the JVM to efficiently access the classes and their members.
  • Initialization Phase

    • The class loader initializes the class by invoking its constructor. This process is managed by the JVM's clint method, which generates the initialization code dynamically based on the class structure.
  • Class Loader Types

    In the JVM, class loading is delegated to different class loaders. These include:

  • Bootstrap Class Loader (BootstrapClassLoader)

    • Written in C and responsible for loading core Java libraries (e.g., java.lang, javax, sun packages).
    • Operates in a isolated sandbox environment.
  • Extension Class Loader (ExtClassLoader)

    • Loads classes from the JAVA_HOME/jre/lib/ext directory. It allows third-party vendors to add their own classes by placing JAR files in this directory.
  • Application Class Loader (AppClassLoader)

    • Responsible for loading application classes from the classpath. It delegates loading requests to the Extension Class Loader unless a specific class is already loaded.
  • Double-Checked Locking Mechanism

    The class loader ensures that each class is loaded only once through the double-checked locking mechanism. This involves:

  • Checking if the class is already loaded.
  • If not, initiating the loading process.
  • Once the class is loaded, subsequent checks return the loaded class without re-loading.
  • This mechanism also supports the JVM's sandbox environment, preventing external classes from overriding core Java classes.

    Understanding the class loading mechanism is crucial for Java developers as it affects Everything from development to debugging, especially when dealing with classpath issues or performance optimizations.

    By mastery of the class loader architecture, you gain insight into how the JVM manages and enhances the dynamic nature of Java applications.

    转载地址:http://itozk.baihongyu.com/

    你可能感兴趣的文章
    nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
    查看>>
    NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>
    NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
    查看>>
    NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka消费者处理器_来消费kafka数据---大数据之Nifi工作笔记0037
    查看>>
    NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
    查看>>
    NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
    查看>>
    NIFI大数据进阶_NIFI监控功能实际操作_Summary查看系统和处理器运行情况_viewDataProvenance查看_---大数据之Nifi工作笔记0026
    查看>>
    NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
    查看>>
    NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
    查看>>
    NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
    查看>>
    NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
    查看>>
    NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
    查看>>
    NIFI大数据进阶_实时同步MySql的数据到Hive中去_可增量同步_实时监控MySql数据库变化_操作方法说明_01---大数据之Nifi工作笔记0033
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_01_实际操作---大数据之Nifi工作笔记0029
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_说明操作步骤---大数据之Nifi工作笔记0028
    查看>>
    NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
    查看>>