博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JVM 内存结构
阅读量:4086 次
发布时间:2019-05-25

本文共 895 字,大约阅读时间需要 2 分钟。

1、程序计数器

Java 虚拟机的多线程是通过线程轮流切换并分配处理器执行时间的方式实现,所以确定的时刻一个处理器只会执行一个线程中的指令。

为了线程切换后能恢复到正确的执行位置,每个线程都需要一个独立的程序计数器,用于记录线程所执行字节码指令的地址。

2、虚拟机栈

虚拟机栈是线程私有的。每个方法执行时会创建一个帧栈,用于存储局部变量表、操作数栈、动态链接、方法出口等信息。当方法调用时,栈帧入栈,方法结束时,栈帧出栈。

局部变量表的所需的内存空间在编译期间完成分配,运行时不会改变大小。

虚拟机栈定义了两种异常状况:StackOverFlowError 和 OutOfMemoryError 。

  • StackOverFlowError:线程请求的栈深度大于虚拟机所允许的深度。
  • OutOfMemoryError :大多数虚拟机都允许动态扩展虚拟机栈的大小,所以线程可以一直申请栈,直到内存不足时,抛出 OutOfMemoryError。

3、本地方法栈

本地方法栈为虚拟机使用到的 native 方法服务。Sun HotSpot 虚拟机直接把虚拟机栈与本地方法栈合二为一。与虚拟机栈一样,也会抛出 StackOverFlowError 和 OutOfMememoryError 异常。

4、Java 堆

Java 堆是垃圾收集器管理的主要区域,也称为 GC 堆。所有实例和数组都在这里分配内存,也是线程共享的内存区域。

-Xms 设置最小值;-Xmx 设置最大值。

5、方法区

与 Java 堆一样,也是线程共享的内存区域,用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译后的代码等数据。

在 HotSpot 虚拟机中,这块区域对应永久代,不易被回收。

运行时常量池:属于方法区一部分。用于存放编译期生成的常量和引用。

6、直接内存

直接内存并不是虚拟机内存的一部分,也不是 Java 虚拟机规范中定义的内存区域。jdk1.4 中新加入的 NIO,引入了通道与缓冲区的 IO 方式,它可以调用 Native 方法直接分配堆外内存,这个堆外内存就是本机内存,不会影响到堆内存的大小。

转载地址:http://vskii.baihongyu.com/

你可能感兴趣的文章
JavaScript实现页面无刷新让时间走动
查看>>
CSS实例:Tab选项卡效果
查看>>
前端设计之特效表单
查看>>
前端设计之CSS布局:上中下三栏自适应高度CSS布局
查看>>
Java的时间操作玩法实例若干
查看>>
JavaScript:时间日期格式验证大全
查看>>
pinyin4j:拼音与汉字的转换实例
查看>>
XML工具代码:SAX从String字符串XML内获取指定节点或属性的值
查看>>
时间日期:获取两个日期相差几天
查看>>
责任链模式 Chain of Responsibility
查看>>
高并发与大数据解决方案概述
查看>>
解决SimpleDateFormat线程安全问题NumberFormatException: multiple points
查看>>
MySQL数据库存储引擎简介
查看>>
处理Maven本地仓库.lastUpdated文件
查看>>
Kafka | 请求是怎么被处理的?
查看>>
Java并发编程1-线程池
查看>>
CentOS7,玩转samba服务,基于身份验证的共享
查看>>
计算机网络-网络协议模型
查看>>
计算机网络-OSI各层概述
查看>>
Java--String/StringBuffer/StringBuilder区别
查看>>