JVM中的堆

网友投稿 744 2022-09-03

JVM中的堆

JVM中的堆

内存结构

堆的核心概念

《java虚拟机规范》中对java堆的描述是:所有的对象实例以及数组都应当在运行时分配在堆上。一个JVM实例只存在一个堆内存(就是new 出来一个对象),java内存管理的核心区域java堆区在jvm启动的时候就被创建,空间大小确定。是jvm管理的最大一块内存空间《java虚拟机规范》规定,堆可以处于物理上不连续的内存空间,但是在逻辑上应该被视为连续的所有的线程共享java堆,在这里还可以划分线程私有的缓冲区(Thread Local Allocation Buffer, TLAB)数组和对象可能永远不会存储在栈上,栈帧中保存引用,这个引用指向对象或者数组在堆中的位置。垃圾回收的重点区域方法结束后,堆中的对象不会马上移除

内存细分

java 7以及之前堆内存逻辑上分为:新生区+养老区+永久区java 8以及之后堆内存逻辑上分为:新生区+养老区+元空间

堆空间大小设置:

“-Xms”:【-X是jvm运行参数,ms是memory start】表示堆区(年轻代+老年代)的起始内存,等价于-XX:InitialHeapSize"-Xmx"表示堆区(年轻代+老年代)的最大内存,等价于-XX:MaxHeapSize堆区内存超过指定的最大内存,报OOM通常将-Xms和-Xmx设置相同的参数。目的是为了在java进行垃圾清理堆后,不需要重新分隔计算堆区的大小,提高性能。-XX:NewRation:设置新生代与老年代的比例。默认值2-XX:SurvivorRatio:设置新生代中Eden区与survivor区的比例

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:10分钟搞懂:亿级用户的分布式数据存储解决方案!(大数据分布式存储方案)
下一篇:PHP基于Redis实现轻量级延迟队列(php通过redis限流)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~