继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

13 张图解 Java 中的内存模型

码农突围
关注TA
已关注
手记 359
粉丝 21
获赞 151

前言

  • 了解Java中的对象、变量等存放的内存区域十分重要
  • 本文将全面讲解Java虚拟机中的内存模型 & 分区,希望你们会喜欢

目录
在这里插入图片描述
1.内存模型 & 分区

Java虚拟机在运行Java程序时,会管理着一块内存区域:运行时数据区

在运行时数据区里,会根据用途进行划分:

  • Java虚拟机栈(栈区)
  • 本地方法栈
  • Java堆(堆区)
  • 方法区
  • 程序计数器
    在这里插入图片描述
    下面,我将详细介绍每个内存模型分区

2.Java堆
在这里插入图片描述
简介
在这里插入图片描述
3. Java虚拟机栈
在这里插入图片描述
简介
在这里插入图片描述
4. 本地方法栈
在这里插入图片描述
简介:十分类似Java虚拟机栈,与Java虚拟机区别在于:服务对象,即Java虚拟机栈为执行 Java 方法服务;本地方法栈为执行 Native方法服务

5.方法区
在这里插入图片描述
简介
在这里插入图片描述
注:其内部包含一个运行时常量池,具体介绍如下:
在这里插入图片描述
6.程序计数器
在这里插入图片描述
简介
在这里插入图片描述
7. 额外知识:直接内存

  • 定义:NIO类(JDK1.4引入)中基于通道和缓冲区的I/O方式 通过使用Native函数库 直接分配 的堆外内存
  • 特点:不受堆大小限制
    不属于虚拟机运行时数据区的一部分 & 不在堆中分配
  • 应用场景:适用于频繁调用的场景
    通过一个 存储在Java堆中的DirectByteBuffer对象 作为这块内存的引用 进行操作,从而避免在 Java 堆和 Native堆之间来回复制数据,提高使用性能
  • 抛出的异常:OutOfMemoryError,即与其他内存区域的总和 大于 物理内存限制

8. 总结
本文全面讲解JVM中的内存模型 & 分区,总结如下
在这里插入图片描述
作者:Carson_Ho

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP