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

    你可能感兴趣的文章
    SpringBoot中重写addCorsMapping解决跨域以及提示list them explicitly or consider using “allowedOriginPatterns“ in
    查看>>
    PageHelper 解析及实现原理
    查看>>
    pageHelper分页工具的使用
    查看>>
    pageHelper分页技术
    查看>>
    PageHelper分页查询遇到的小问题
    查看>>
    PageHelper实现分页详细版、整合SSM应用
    查看>>
    PageHelper常见问题
    查看>>
    SpringBoot中配置为开发模式,代码修改后不用重新运行
    查看>>
    springboot中pom.xml、application.yml、application.properties
    查看>>
    PageHelper:上手教程(最详细)
    查看>>
    PageOffice如何实现从零开始动态生成图文并茂的Word文档
    查看>>
    PageRank算法
    查看>>
    Paint类(画笔)
    查看>>
    paip. 调试技术打印堆栈 uapi print stack java php python 总结.
    查看>>
    paip.android 手机输入法制造大法
    查看>>
    paip.spring3 mvc servlet的配置以及使用最佳实践
    查看>>
    Palindrome Number leetcode java
    查看>>
    Palo Alto Networks Expedition 未授权SQL注入漏洞复现(CVE-2024-9465)
    查看>>
    Palo Alto Networks Expedition 远程命令执行漏洞(CVE-2024-9463)
    查看>>
    Palo Alto Networks PAN-OS身份认证绕过导致RCE漏洞复现(CVE-2024-0012)
    查看>>