java8 内存模型_java8内存模型

edca7ed0b95e57fa83aabb18adeee9a7.png

虚拟机栈:线程私有,随线程创建而创建。栈里面是一个一个“栈帧”,每个栈帧对应一次方法调用。栈帧中存放了局部变量表(基本数据类型变量和对象引用)、操作数栈、方法出口等信息。当栈调用深度大于JVM所允许的范围,会抛出StackOverflowError的错误。

本地方法栈:线程私有,这部分主要与虚拟机用到的Native方法相关,基本等同于虚拟机栈,存放得是native方法帧,可出现SOF和OOM错误。

程序计数器:也叫PC寄存器,JVM支持多个线程同时运行,每个线程都有自己的程序计数器。倘若当前执行的是 JVM 的方法,则该寄存器中保存当前执行指令的地址;倘若执行的是native方法,则PC寄存器中为空。(PS:线程执行过程中并不都是一口气执行完,有可能在一个CPU时钟周期内没有执行完,由于时间片用完了,所以不得不暂停执行,当下一次获得CPU资源时,通过程序计数器就知道该从什么地方开始执行)

元空间(metaSpace):所有线程共享。存放class加载相关信息。

堆:所有线程共享。存放new出来的数组和对象数据,以及类的静态变量。同时,包含一个常量池(final),是由1.7以前版本的方法区转移过来的。当申请不到空间时会抛出OutOfMemoryError。堆内存里面划分年轻代和年老代

运行时启动参数调优:

c59236022b0f90d8d3814952c7d0413e.png

-Xms和-Xmx

用于设置堆内存的大小

-XX:NewSize和-XX:MaxNewSize

用于设置年轻代的大小,建议设为整个堆大小的1/3或者1/4,两个值设为一样大。

-XX:SurvivorRatio

用于设置Eden和其中一个Survivor的比值,这个值也比较重要。

-XX:NewRatio=3代表新生代和老年代的比例为1:3

需要注意的是,JDK8中已经用Metaspace(元数据区)完全替代了永久代(即方法区)

而且元数据区内存不在JVM中,而是使用的本地内存,默认情况下受操作系统内存限制。

调整元数据区内存大小的参数 -XX:MetaspaceSize -XX:MaxMetaspaceSize

垃圾回收机制调优:

965d74298c2280fb8b8d0a3b85177e66.png

GC主要分二类,新生代GC,老年代GC;

新生代GC包括:串行GC、并行GC、并行回收GC

老年代GC包括:串行GC、并行GC、CMS

G1比较特殊,同时支持新生代和老年代

GC选择:

GC在选择上,主要关注两点,吞吐量优先和暂停时间优先,

对于吞吐量优先的采用server默认的并行GC(Parallel GC)方式(上图蓝色区域),

对于暂停时间优先的选用并发GC(CMS)方式(上图黄色区域),常用场景:互联网、电商类

常用GC开启方式

暂停时间优先: 并行GC + CMS

开启方式[ -XX:+UseConcMarkSweepGC -XX:+UseParNewGC ]

吞吐量优先: 并行回收GC + 并行GC

开启方式 [ -XX:+UseParallelOldGC ] ,此GC也时server模式默认的配置

G1: [ -XX:+UseG1GC ]

适用于服务器端、大内存、多CPU情景的垃圾收集器;

G1的目标是在维持高效率回收的同时,提供软实时中断特性

常用场景:hadoop、elasticsearch

CMS和G1区别

Cms 堆 -> 年轻代老年代

G1 堆 -> 多个区 -> 每个区里(年轻代老年代)

Cms 标记清理算法

G1 压缩复制算法,不产生碎片

G1 时间停顿可设置,相关参数[ -XX:MaxGCPauseMillis=100 -XX:GCPauseIntervalMillis=200 ]

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值