JVM(内存区域划分)

本文介绍了Java虚拟机(JVM)的工作原理,包括内存区域的划分(如本地方法栈、虚拟机栈、堆区、元数据区),以及如何确定变量存储位置的基本原则。重点讲解了线程私有和线程共享的不同内存区域。
摘要由CSDN通过智能技术生成

JVM

JVM - Java虚拟机
我们编写的 Java 程序, 是不能够被 OS 直接识别的
JVM 充当翻译官的角色, 负责把我们写的的 Java 程序 ,翻译给 OS “听”, 让 OS 能够识别我们所写的 Java 代码


JVM 内存区域划分

JVM 是一个应用程序, 在启动的时候, 会从 操作系统 申请到一整块很大的内存区域
并且 JVM 会根据需要, 将整个内存区域, 根据功能进行划分

JVM运行时数据区(内存布局)
在这里插入图片描述

Native Method Stacks (本地方法栈) : 存储本地方法 (JVM 内部方法) 之间的调用关系

  • 线程私有

Program Counter Register (程序计数器) : 记录当前正在执行指令的地址

  • 线程私有

JVM Stacks (虚拟机栈) : 描述 Java 方法之间的调用关系,存储基本数据类型和对象的引用(不是对象本身, 是对象的引用,对象存储在Heap区)

  • 线程私有
  • 整个栈空间内部,可以任务是包含很多个元素, 每个元素表示一个方法, 每个元素称为一个 “栈帧” ,每个栈帧里会包含该方法的 入口地址,方法参数,返回地址, 形参, 局部变量 …

Heap (堆区) : 整个 JVM 空间最大的区域, 存储程序中创建的所有的对象的实例.

  • 线程共享
  • 堆里面分为两个区域 : 新生代和老生代 ( 新生代包含三个区域: 一个Endn+ 和两个 Survivor(S0/S1) )

Metaspace (元数据区/方法区) : 存储类对象, 常量池, 静态成员

  • 线程共享
  • 一个进程只有一块, 多个线程共用

对给出的一段代码, 判断某个变量在哪个区域上?

遵循原则:

  • 局部变量在 栈
  • 普通成员变量在 堆
  • 静态成员变量在 方法区/元数据区
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值