一、jvm内存结构 包含 方法区、虚拟机栈、本地方法栈、堆、程序计数器 如下图
1.1 方法区 (Method Area)
方法区:主要存储 虚拟机加载的类信息、常量、静态变量。jdk1.8版本后也称“永久区”,是所有线程共享的资源。当永久区区域内存消耗解决上限,就会触发FullGC
- -XX:PermSize 设置永久代最小空间大小
- -XX:MaxPermSize 设置永久代最大空间大小
1.2 虚拟机栈(VM Stack)
虚拟机栈:占用的主要是操作系统内存,一个线程对应一个虚拟机栈,它是线程私有的,生命周期和线程一样,线程每执行一个方法,对应的栈会创建一个栈帧。栈帧会存储局部变量表、动态链接、操作数和方法出口等信息,执行方法,栈帧入栈,方法执行完,栈帧出栈。如下图:
1.3 本地方法栈(Native Method Stack)
本地方法栈和虚拟机栈的运行机制一致,二者区别--------》虚拟机栈执行Java方法,本地方法栈执行native方法。
1.4 堆(Heap)
堆内存划分为 新生代、老年代。
新生代分为 eden、survivor区,比例一般 8:1:1 。一般特别大的对象直接分配到老年代;小对象分配到eden区,经过一次垃圾回收,未被回收的对象将放到 survivor区,多次未被回收的对象放到老年代。两个survivor区之间采用复制算法,老年代采用标记压缩算法。后续文章持续更新相关算法。
并行:例如2核cpu,1个cpu负责一个任务同时执行
并发:一个cpu负责多个任务,调度执行,切分时间片划分(例如每个线程执行50毫秒),交替执行
相关参数调试:
- -Xms: 设置堆的最小空间大小
- -Xmx: 设置堆的最大空间大小
- -Xmn: 设置年轻代大小
- -XX:NewSize 设置新生代最小空间大小
- -XX:MaxNewSize 设置新生代最大空间大小
ps --------------------------------------------------------------------------------------------------------------------
强引用、软引用、弱引用、虚引用。
强引用:new出来的对象都是强引用,GC无论如何都不会回收,即使抛出OOM异常。
软引用:只有当JVM内存不足时才会被回收。
弱引用:只要GC,就会立马回收,不管内存是否充足。
虚引用:做一些跟踪记录,辅助finalize函数的使用。