jvm内存模型

java运行时数据区,jvm内存模型:
这里写图片描述
1. 程序计数器

程序计数器是一块较小的内存区域,它可以看成当前线程执行字节码的行号指示器。 每个线程都有自己独立的程序计数器,各个线程互不影响。
因为在任何一个时刻,一个处理器只能处理一个线程,所有程序计数器,还起到了线程切换后的恢复正确的执行位置。
此内存区域是jvm唯一一个没有OutOfMemoryError的区域。

1. 虚拟机栈

虚拟机栈也是线程私有的,每一个方法在执行的同时都会创建一个栈帧,存储局部变量表、操作数栈、动态链接、方法出口等信息。每个方法的
调用过程都对应一个栈帧在虚拟机栈中入栈到出栈的过程。请求的栈深度超过虚拟机允许的则会抛出StackOverflowError异常;如果扩展时申请
申请不到足够的内存则抛出OutOfMemoryError异常。

1. 本地方法栈

本地方法栈和虚拟机栈相似,但是本地方法栈为虚拟机使用到的native方法服务。

1. 堆

jvm中内存最大的一块,被所有线程共享,存放对象实例,是垃圾收集器主要管理的区域,也称GC堆。堆还可以细分为新生代 和老年代,新生代还可
以分为Eden(伊甸园), From Survivor区, To Survivor区 。 从内存分配的角度来看,还可以划分出很多线程私有的分配缓存区TLAB。划分的木都是为
了更好的回收和分配内存。堆在物理上可以不连续,所以支持扩展 , -Xmx -Xms控制。 当堆中没有内存完成实例分配,并且堆无法扩展时,将会抛出OutOfMemoryError。

1. 方法区

它也是线程共享的区域,它存储 被jvm加载的类信息、常量、静态变量、即时编译器编译后的代码数据。 (hotspot)愿意成为永久代。但实质上不是,-XX:MaxPermSize。
方法区无法满足内存分配时,会抛出OutOfMemoryError异常。
运行时常量池

创建内存在堆内存分配的内存空间。
“指针碰撞 : 如果内存足够规整已使用的和未使用的空间规整化一,可以使用“指针碰撞”的方式分配内存。
“空闲列表” : 如果堆中的内存杂乱无章,已分配和未分配的空间很乱,jvm就需要通过一个列表来维护未分配空间的地址,根据内存分配的需求“空闲列表”,选择一个足够大的空间给在这个对象。
TLAB : TLAB也是堆中分配内存的方法,按照线程划分内存空间,哪个线程需要创建对象使用内存,就在哪个线程的区域分配。 可以使用 -XX:+/-UseTLAB 开启tlab的方式

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值