1. jvm整体结构
类加载子系统:负责将类加载到jvm内存
字节码执行引擎:负责执行字节码指令以及修改程序计数器行号
JVM运行时数据区域:包括堆,虚拟机栈,本地方法栈,方法区
2. JVM内存模型
堆:垃圾回收器主要工作的区域,用于存放实例对象
虚拟机栈:描述的是java执行方法的内存模型,java执行方法的时候,就会创建一个栈帧,用于存放局部变量表,操作数栈,动态链接,方法出口等信息。每个方法从开始执行到结束都对应着一个栈帧在虚拟机栈中入栈到出栈的过程。
本地方法栈:对应程序中native方法
方法区:存放类的信息,静态变量以及常量等。
程序计数器:和虚拟机栈一样都是线程私有的,用来表示当前线程所执行字节码的行号。当CPU时间片切换时有了程序计数器才能知道当前程序所执行的位置。
3. 内存参数设置
堆:-Xms -Xmx -Xmn
栈:-Xss,栈内存设置的越大,所存放的栈帧数越多,但是JVM中能开启的线程数会越少。
方法区:-XX:metaspaceSize -XX:MaxMetaspaceSize ,方法区默认大小21M,通常需要设置成256M,因为程序启动时动态扩容会造成大量fullgc,程序启动缓慢。