博客
关于我
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/

    你可能感兴趣的文章
    Nginx配置负载均衡到后台网关集群
    查看>>
    Nginx配置限流,技能拉满!
    查看>>
    Nginx面试三连问:Nginx如何工作?负载均衡策略有哪些?如何限流?
    查看>>
    Nginx:NginxConfig可视化配置工具安装
    查看>>
    ngModelController
    查看>>
    ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
    查看>>
    ngrok内网穿透可以实现资源共享吗?快解析更加简洁
    查看>>
    NHibernate学习[1]
    查看>>
    NHibernate异常:No persister for的解决办法
    查看>>
    NIFI1.21.0_java.net.SocketException:_Too many open files 打开的文件太多_实际操作---大数据之Nifi工作笔记0051
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
    查看>>
    NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>