JVM运行时数据区

  

一、程序计数器

每个线程独有的,如果执行的是JAVA方法,则记录当前线程正在执行的字节码指令地址,如果执行的是Native 方法,值为undefined,程序计数器是唯一不会出现OOM的内存区域

二、虚拟机栈

  • 每个线程独有,随着线程的创建而创建,随着线程的销毁而销毁
  • 每个方法执行的同时会创建栈帧,只有位于顶部的栈帧才是有效栈帧,称为当前栈帧
  • 栈帧会存储局部变量表、操作数栈、动态链接、方法出口等
  • 执行引擎执行的所有操作只针对当前栈帧
  • 栈帧随着方法的调用而创建,随着方法的结束和销毁
  • 当线程申请大于虚拟机栈的深度就会抛出StackOverflowError异常
  • 扩展时无法申请到足够的内存就会抛出OutOfMemoryError异常

三、本地方法栈

Java虚拟机栈类似。区别在于,本地方法栈为虚拟机运行native方法服务

四、堆

所有线程共享的,JVM管理的最大的一块内存空间,主要用于存放各种类的实例对象。垃圾回收就是回收堆。JVM创建对象一般都是创建在堆上,但为了提高效率,有时候也会在栈上分配。堆中包含新生代和老年代,比例为新生代1/3,老年代2/3,新生代按照8:1:1的比例分为Eden和两个幸存区Survivor(from和to)

大小参数设置: -Xms:堆的最小值;-Xmx:堆的最大值;-Xmn:新生代的大小;-XX:NewSize;新生代最小值;-XX:MaxNewSize:新生代最大值

五、元数据区

元数据区是在1.8之后才出现的,用来替换之前的永久代元数据区永久代都是JVM方法区的实现。此区域主要用来保存被虚拟机加载的类信息、常量、静态变量以及即时编译器编译后的代码等数据。

大小参数设置:-XX:MetaspaceSize=5M;-XX:MaxMetaspaceSize=50M

六、直接内存(堆外内存)

直接内存不是虚拟机运行时数据区的一部分,是操作系统管理的内存,提高使用NIO的效率,使用完后需要手动回收

大小参数设置:-XX:MaxDirectMemorySize(默认与堆内存大小一样)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值