1.jvm内存结构
堆:线程共享主要是存放对象实例和数组
元空间取代持久代是因为持久代会报错OutOfMemoryError,大小不好确定
虚拟机栈:
线程隔离 栈帧组成,内容:局部变量表、操作数栈(存放临时变量)、指向运行时常量池的应用、方法返回地址、动态连接
本地方法栈:线程隔离
程序计数器:线程隔离
方法区:
线程共享 方法区和堆存在交集
常量池-静态常量池,也叫class文件常量池,主要存放:
1.字面量:例如文本字符串、final修饰的常量
2.符号引用:例如类和接口的全限定名、字段的名称和描述符、方法名称和描述符
常量池-运行时常量池 当类加载到内存中后,jvm会把静态常量池的内容存放到运行时常量池中;运行时常量池主要存放是编译期生成的字面量、符号引用等
常量池-字符串常量池,可以理解为运行时常量池的一部分、类加载到内存的时候,字符串会存到字符串常量池中
2.类加载过程
加载过程
读取类的二进制流
将二进制流转为方法区的数据结构,存入方法区
在java堆产生java.lang.Class对象
3.编译器优化
一开始一般由解释器解释执行
当虚拟机发面某个方法或者代码块执行特别频繁的时候,就会认为这些代码是“热点代码”,为提高热点代码的执行效率,会用即时编译器(JIT)把这些代译成和本地平台相关的机器码,并进行各层次优化
hotspot的即时编译器-C1:是一个简单快速的编译器,关注局部性优化,适用于执行时间比较短对启动性能有要求的程序,如GUI应用对界面启动速度有要求,又称Client complier
hotspot的即时编译器-C2:是为长期运行的服务端应用程序做性能调优的编译器,适用于执行时间比较长对峰值性能有要求的程序,又称server complier