13 张图解 Java 中的内存模型

admin 2020年8月30日13:50:32评论244 views字数 907阅读3分1秒阅读模式

点击上方 Java后端选择 设为星标

优质文章,及时送达


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

目录

13 张图解 Java 中的内存模型

1. 内存模型 & 分区


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

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

  1. Java虚拟机栈(栈区)
  2. 本地方法栈
  3. Java堆(堆区)
  4. 方法区
  5. 程序计数器

13 张图解 Java 中的内存模型

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


2. Java堆


13 张图解 Java 中的内存模型
简介
13 张图解 Java 中的内存模型


3. Java虚拟机栈



13 张图解 Java 中的内存模型

简介
13 张图解 Java 中的内存模型

4. 本地方法栈


13 张图解 Java 中的内存模型  
简介:十分类似Java虚拟机栈,与Java虚拟机区别在于:服务对象,即Java虚拟机栈为执行 Java 方法服务;本地方法栈为执行 Native方法服务

搜索 Java后端 公众号,回复“666”,送你一份Java面试题宝典


5. 方法区



13 张图解 Java 中的内存模型
简介
13 张图解 Java 中的内存模型
注:其内部包含一个运行时常量池,具体介绍如下:
13 张图解 Java 中的内存模型

6. 程序计数器


13 张图解 Java 中的内存模型
简介
13 张图解 Java 中的内存模型  

7. 额外知识:直接内存


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


8. 总结


本文全面讲解JVM中的内存模型 & 分区,总结如下


13 张图解 Java 中的内存模型

作者:Carson_Ho  

链接:juejin.im/post/6844903677279338509

- END -

最近整理一份面试资料《Java技术栈学习手册》,覆盖了Java技术、面试题精选、Spring全家桶、Nginx、SSM、微服务、数据库、数据结构、架构等等。
获取方式:点“ 在看,关注公众号 Java后端 并回复 777 领取,更多内容陆续奉上。
读 
1. 图解 SQL
2. 推荐两个学算法的 GitHub 项目
3. 一条 SQL 引发的事故
4. 贼 TM 好用的 Java 工具类库

5. 推荐 5 款好用的REST API工具

13 张图解 Java 中的内存模型

在看 13 张图解 Java 中的内存模型

  • 左青龙
  • 微信扫一扫
  • weinxin
  • 右白虎
  • 微信扫一扫
  • weinxin
admin
  • 本文由 发表于 2020年8月30日13:50:32
  • 转载请保留本文链接(CN-SEC中文网:感谢原作者辛苦付出):
                   13 张图解 Java 中的内存模型http://cn-sec.com/archives/110628.html

发表评论

匿名网友 填写信息