当前位置:网站首页>JVM内存和垃圾回收-03.运行时数据区概述及线程
JVM内存和垃圾回收-03.运行时数据区概述及线程
2022-08-02 18:40:00 【J___code】

1.概念
- 内存:硬盘和CPU之间的仓库和桥梁,承载着操作系统和应用程序的实时运行
- JVM内存布局:该布局规定了Java在运行时内存申请、分配、管理的策略,保证JVM的高效稳定运行,不同的JVM对于内存的划分方式和管理机制存在差异
- JVM和线程的运行时数据区:JVM定义了若干程序运行时使用到的运行时数据区。一些随着JVM启动而创建(可以理解为启动一个JVM进程),随着JVM退出而销毁;另一些随着线程开始和结束而创建和销毁:
图中灰色部分为单个线程私有的数据区,包括PC寄存器、栈、本地栈;红色为多个线程共享的,包括堆和堆外内存(永久代或元空间、代码缓存)
tips:
- JVM内存布局中元数据区和
JIT编译产物合成为元空间(JDK8的名称,即方法区)- 垃圾回收主要针对堆区,小部分针对方法区
- 每个JVM只有一个
Runtime实例(即运行时数据区)
2.线程
- 线程是程序的运行单元,JVM允许一个应用有多个线程并行执行
- 在Hotspot JVM中,每个Java线程都和操作系统的本地线程直接映射(即线程准备执行时,本地线程也会同时创建;线程执行终止后,本地线程也会回收)
- 操作系统负责将所有线程调度到任何一个可用CPU上,一旦线程初始化成功,它就会调用Java线程中的
run方法
边栏推荐
猜你喜欢
随机推荐
互联网寒冬,挚友7面阿里,终获Offer
Interviewer: can you talk about optimistic locking and pessimistic locks
如何获取EasyCVR平台设备通道的RTMP视频流地址?
js Fetch返回数据res.json()报错问题
浅谈一下pyd文件的逆向
监控易火星版即将亮相:分布式运维帮助TOP3000大企业跨越管理鸿沟
VSTO踩坑记录(1)- 从零开始开发outlook插件
淘宝|蚂蚁|菜鸟|盒马|嘀嘀|饿了么面经(已拿多个offer)
Openharmony - 基于ArkUI(TS)开发颜色选择器
从技术全景到场景实战,透析「窄带高清」的演进突破
MySQL主从搭建(问题大聚集,告别部署烦恼)
小姐姐面试蚂蚁金服被虐经历,心疼...
selenium installation and environment configuration firefox
2022最新彩虹表
开源一夏 | Web开发(七):登录实现及功能测试
Mobile Banking Experience Test: How to Get the Real User Experience
Mppt photovoltaic maximum power point tracking control matlab simulation
Mppt光伏最大功率点跟踪控制matlab仿真
【C语言刷题】双指针原地修改数组(力扣原题分析)
“12306”的架构到底有多牛逼?











