java new对象内存模型_13 张图解 Java 中的内存模型

前言

了解Java中的对象、变量等存放的内存区域十分重要

本文将全面讲解Java虚拟机中的内存模型 & 分区,希望你们会喜欢

目录

afca8dc0a05b1e49f3952d9f4ebcbcad.png

1. 内存模型 & 分区

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

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

Java虚拟机栈(栈区)

本地方法栈

Java堆(堆区)

方法区

程序计数器

98a1e250d9c4f39a6993955c4e41c436.png

下面,我将详细介绍每个内存模型分区

2. Java堆

e76a83ced2061b0571ef7b724f6cd460.png

简介

a12d4bdbb106dde5f6b29fb79ff6425f.png

3. Java虚拟机栈

2b8a461a0eb8bce37e596fa0055d1444.png

简介

975e7f2ac626dddf10c1cbebd007ce13.png

4. 本地方法栈

828e06349a8743a28d85bfbb1652fa32.png

简介:十分类似Java虚拟机栈,与Java虚拟机区别在于:服务对象,即Java虚拟机栈为执行 Java 方法服务;本地方法栈为执行 Native方法服务

5. 方法区

379f43c2b926c522eda2fd675b5168bf.png

简介

d879fb3b66bc2cd27efe8e1900ace9fc.png

注:其内部包含一个运行时常量池,具体介绍如下:

45bb7401ae68894ae556b66702e1ad93.png

6. 程序计数器

380cc5def355a41749798179e926d31e.png

简介

ffe3247a4bee5d003a8398606bec8abd.png

7. 额外知识:直接内存

定义:NIO类(JDK1.4引入)中基于通道和缓冲区的I/O方式 通过使用Native函数库 直接分配 的堆外内存

特点:不受堆大小限制

不属于虚拟机运行时数据区的一部分 & 不在堆中分配

应用场景:适用于频繁调用的场景

通过一个 存储在Java堆中的DirectByteBuffer对象 作为这块内存的引用 进行操作,从而避免在 Java 堆和 Native堆之间来回复制数据,提高使用性能

抛出的异常:OutOfMemoryError,即与其他内存区域的总和 大于 物理内存限制

END

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值