JVM运行时数据区及内存分配策略
2021/12/6 7:20:58
本文主要是介绍JVM运行时数据区及内存分配策略,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
运行时数据区
运行时数据区也就是JVM运行时产生的数据存放的区域,这块区域就是JVM的内存区域,也称为JVM的内存模型–JMM
JMM分成了以下几部分:
- 堆空间(线程共享):存放new出来的对象
- 元空间(线程共享):存放类元信息、类的模板、常量池、静态部分。
- 线程栈(线程独享):存放方法的栈帧
- 本地方法区(线程独享):本地方法产生的数据
- 程序计数器(线程独享):配合执行引擎来执行指令
内存分配策略
为对象分配内存,具体的分配策略如下:
- Bump the pointer(指针碰撞):如果内存空间是绝对规整的,则JVM记录当前剩余内存的指针,然后为对象分配内存。
- Free List(空闲列表):如果内存空间的分配不规整,那么JVM会维护一个可用内存空间的列表用于分配。
对象并发分配存在的问题:
- Compare And Swap:自旋分配,如果并发分配失败则重试分配之后的地址。
- Thread Local Allocation Buffer(TLAB):本地线程分配缓冲,JVM被每个线程分配一个空间,每个线程在自己的空间中创建对象(jdk8默认使用,之前版本需要通过-XX:+UseTLAB开启)
这篇关于JVM运行时数据区及内存分配策略的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-04百万架构师第六课:设计模式:策略模式及模板模式
- 2025-01-04百万架构师第七课:设计模式:装饰器模式及观察者模式
- 2025-01-04适用于企业管理的协作工具API推荐
- 2025-01-04挑战16:被限流的CPU
- 2025-01-03企业在选择工具时,如何评估其背后的技术团队
- 2025-01-03Angular中打造动态多彩标签组件的方法
- 2025-01-03Flask过时了吗?FastAPI才是未来?
- 2025-01-0311个每位开发者都应知道的免费实用网站
- 2025-01-03从REST到GraphQL:为什么以及我是如何完成转型的
- 2025-01-03掌握RAG:从单次问答到连续对话