点击上方蓝色字体,选择“标星公众号”
优质文章,第一时间送达关注公众号后台回复pay或mall获取实战项目资料视频
点击此链接:一套的SpringCloud版聚合支付项目,资料文档教程齐全作者:Carson_Ho
链接:juejin.im/post/6844903677279338509
前言
了解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中的内存模型 & 分区,总结如下
有热门推荐????头条二面:宕机后,Redis如何实现快速恢复?
使用IntelliJ IDEA查看类图,内容极度舒适
牛!一个比传统数据库快 100-1000 倍的数据库
短 URL 服务,怎么设计与实现?
万字详解,JDK8 的 Lambda、Stream 和日期的使用详解
干货分享:扫码关注下面的公众号后台回复“99”领取99套实战项目+资料
想充电就关注程序员闪充宝
点击阅读原文,获免费JVM+MySQL+设计模式+分布式+微服务完整面试资料