zoukankan      html  css  js  c++  java
  • JVM类加载机制

    描述
    虚拟机把描述类的数据从Class文件加载到内存,并对数据进行检验、准备、解析和初始化,最终形成可以被虚拟机直接使用的Java类型,这就是虚拟机的类加载机制

    类加载的过程
    加载、验证、准备、解析初始化  5个阶段所执行的具体动作

    周期包括

    1. 加载(Loading)
    2. 验证(Verification)
    3. 准备(Preparation)
    4. 解析(Resolution)
    5. 初始化(Initialization)
    6. 使用(Using)
    7. 卸载(Unloading)

     

     

     

    总结
    类的执行顺序如下:

    确定类变量的初始值:  在类初始化的时候,在准备阶段jvm会为类变量(static修饰的变量)初始化,如对象会被初始化为null,int被初始化为0
    找到入口执行:             找到main方法,开始执行,在执行之前会对main方法所在类进行初始化
    执行类初始化方法:      JVM 会按顺序收集类变量的赋值语句、静态代码块,组成类初始化方法去执行
    执行对象实例化方法:   JVM 会按照收集成员变量的赋值语句、普通代码块,最后收集构造方法,组成对象实例化方法去执行

    释义:

    符号引用 :

    符号引用以一组符号来描述所引用的目标。符号引用可以是任何形式的字面量,只要使用时能无歧义地定位到目标即可,符号引用和虚拟机的布局无关。个人理解为:在编译的时候一个每个java类都会被编译成一个class文件,但在编译的时候虚拟机并不知道所引用类的地址,多以就用符号引用来代替,而在这个解析阶段就是为了把这个符号引用转化成为真正的地址的阶段。

    参考链接:

     https://blog.csdn.net/x1032019725/article/details/81301614

    https://blog.csdn.net/qq_16216221/article/details/71600535

  • 相关阅读:
    怎么安装Python?
    Ramnit蠕虫病毒分析和查杀
    Exphub[漏洞利用脚本库]
    SMBv3远程代码执行漏洞复现(CVE-2020-0796)
    Tomcat AJP 文件包含漏洞复现(CVE-2020-1938)
    Fastjson远程代码执行漏洞复现
    信息收集之——旁站、C段
    Redis未授权访问漏洞复现与利用
    CSS
    MVC控制器路由
  • 原文地址:https://www.cnblogs.com/lovedaodao/p/10161251.html
Copyright © 2011-2022 走看看