13 张图解 Java 中的内存模型

往期热门文章:

1、推荐 33 个 IDEA 最牛配置,好用到飞起来!

2、如何设计一个超级牛逼的 Feed 流系统

3、终于明白 Java 为什么要加 final 关键字了!

4、为什么MySQL不推荐使用uuid或者雪花id作为主键?

5、RocketMQ 消息丢失场景分析及如何解决!

5、可不可以不用再写 finally ?

本文来源:juejin.im/post/6844903677279338509

1. 内存模型 & 分区

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

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

  1. Java虚拟机栈(栈区)

  2. 本地方法栈

  3. Java堆(堆区)

  4. 方法区

  5. 程序计数器

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

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中的内存模型 & 分区,总结如下

最近热文阅读:
1、推荐 33 个 IDEA 最牛配置,好用到飞起来!
2、如何设计一个超级牛逼的 Feed 流系统
3、终于明白 Java 为什么要加 final 关键字了!
4、RocketMQ 消息丢失场景分析及如何解决!
5、分库分表需要考虑的问题及方案
6、使用IntelliJ IDEA查看类图,内容极度舒适
7、京东把 Elasticsearch 用得真牛逼!日均5亿订单查询完美解决!
8、一招搞定GitHub下载速度到2MB/s
9、熬了一个通宵,终于把7千万个Key删完了
10、Spring Boot 注解大全,一键收藏了!


关注公众号,你想要的Java都在这里

你可能感兴趣的:(java,jvm,spark,jdk,mysql)