类的加载篇

蚂蚁金服:
深入分析ClassLoader,双亲委派机制
描述一下 JVM 加载 Class 文件的原理机制?
类加载器的双亲委派模型是什么?
一面:类加载过程
一面:双亲委派机制及使用原因
 
百度:
类加载的时机
java 类加载过程?
类加载器都有哪些?
简述 java 类加载机制?
 
腾讯:
JVM中类加载机制,类加载过程,什么是双亲委派模型?
类加载器有哪些
 
小米:
双亲委派模型介绍一下
 
滴滴:
JVM类加载机制
一面:讲一下双亲委派模型,以及其优点
 
字节跳动:
什么是类加载器,类加载器有哪些?
 
美团:
Java类加载过程
描述一下jvm加载class文件的原理机制
 
京东:
什么是类的加载?
哪些情况会触发类的加载?
讲一下JVM加载一个类的过程
JVM的类加载机制是什么?
类加载器的双亲委派模型是什么?
双亲委派机制可以打破吗?为什么
 
此外:
简单说说你了解的类加载器


 类加载子系统作用

ClassLoader只负责class文件的加载,至于它是否可以运行,则由Execution Engine决定。

类的加载过程

一、加载:
通过一个类的全限定名获取定义此类的二进制字节流
将这个字节流所代表的静态存储结构转化为方法区的运行时数据结构
在内存中生成一个代表这个类的java.lang.Class对象,作为方法区这个类的各种数据的访问入口
 注意:数组类是如何创建加载的呢?
 
二、链接:
验证(Verify):
目的在于确保Class文件的字节流中包含信息符合当前虚拟机要求,保证被加载类的正确性,不会危害虚拟机自身安全。
主要包括四种验证,文件格式验证,元数据验证,字节码验证,符号引用验证。
准备(Prepare):
为类变量分配内存并且设置该类变量的默认初始值,即零值。
这里不包含用final修饰的static,因为final在编译的时候就会分配了,准备阶段会显式初始化;
这里不会为实例变量分配初始化,类变量会分配在方法区中,而实例变量是会随着对象一起分配到Java堆中。
见LoadClass.java
解析(Resolve):
将常量池内的符号引用转换为直接引用的过程。
事实上,解析操作往往会伴随着JVM在执行完初始化之后再执行。
符号引用就是一组符号来描述所引用的目标。符号引用的字面量形式明确定义在《java虚拟机规范》的Class文件格式中。
在解析阶段,jvm根据字符串的内容找到内存区域中相应的地址,然后把符号引用替换成直接指向目标的指针、句柄、偏移量等,这些直接指向目标的指针、句柄、偏移量就被成为直接引用。
解析动作主要针对类或接口、字段、类方法、接口方法、方法类型等。对应常量池中的CONSTANT_Class_info、CONSTANT_Fieldref_info、CONSTANT_Methodref_info等。
见Demo.java
三、初始化:
初始化阶段就是执行类构造器方法<clinit>()的过程。
此方法不需定义,是javac编译器自动收集类中的所有类变量的赋值动作和静态代码块中的语句合并而来。
构造器方法中指令按语句在源文件中出现的顺序执行。
<clinit>()不同于类的构造器。(关联:构造器是虚拟机视角下的<init>())
若该类具有父类,JVM会保证子类的<clinit>()执行前,父类的<clinit>()已经执行完毕。
虚拟机必须保证一个类的<clinit>()方法在多线程下被同步加锁。
见Clinit.java
 

 


 
 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章