JVM内存区域划分

前言

本文以主流HostspotJVM进行介绍
JVM在启动时,会从操作系统申请到一个很大的内存区域
JVM需要根据需要,把整个空间分成几个部分,每个部分都有各自的功能


内存分布

在这里插入图片描述

一、栈

此处的栈不是数据结构中的栈,是JVM中的一个特定空间
储存的是方法之间的调用关系,整个栈空间的内部,可以认为是包含很多个元素(每个元素表示一个方法),把这里的每个元素称为栈帧,这一个栈帧里,会包含这个方法的入口地址,参数,变量,返回地址。
由于函数调用,也是有“后进先出”的特点

本地方法栈

native就表示是JVM内部的C++代码,就是给调用native方法(JVM内部的方法)准备的栈空间

虚拟机栈

给Java代码方法使用的栈,每个线程有一个栈

二、程序计数器

记录当前线程执行到哪个指令(很小的一块存一个地址),每个线程都有一个程序计数器

三、堆

整个JVM空间最大的区域
new出来的对象,都是在堆上
堆,每个进程只有一个
栈,每个线程只有一个,一个进程有N个

四、元数据区(java8之前叫方法区)

元:Meta属性
存储类对象,常量池,静态成员

总结

1.局部变量在栈
2.普通成员变量在堆
3.静态成员变量在方法区/元数据区

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值