JVM内存结构原理

JVM(Java Virtual Machine)是一种能够运行 Java 程序的虚拟机。

Java 文件经过编译后会生成 class 字节码文件,运行程序时,字节码文件经过类加载器加载进内存。Java 的内存空间主要划分为4个部分:方法区、堆、栈本地方法栈。其中方法区和堆区是所有线程共享的,程序计数器、本地方法栈和栈区是每个线程私有的。

(Stack):用于存放方法中的局部变量,包括编译期基本数据类型和对象引用(地址指针)。每个方法的运行一定在栈中,因为方法在执行的同时会创建一个栈帧(Stack Frame)用于存储局部变量表、操作数栈、动态链接、方法出口等信息。栈是线程私有的,即线程安全。

(Heap):凡是 new 出来的对象都在堆中,堆内存里的对象都有一个16进制的地址值,多线程共享。它是垃圾收集器管理的主要区域,也被成为“GC 堆”。从内存回收角度来看堆可分为:新生代和老生代。从内存分配的角度看,线程共享的 Java 堆中可能划分出多个线程私有的分配缓冲区(Thread Local Allocation Buffer,TLAB)。无论怎么划分,都与存放内容无关,进一步的划分都是为了更好的回收内存,或者更快的分配内存。

方法区(Method Area):与堆一样,是各个线程共享的内存区域,它用于存储已被虚拟机加载的类信息、常量、方法信息、静态变量、即时编译器编译后的代码等数据,也被称为永久区

本地方法栈(Native Method Stack):本地方法栈与栈作用类似,存储本地方法(Native Method)的调用状态。用于 Java 语言调用外部语言(C 语言),使用 native 方法服务,与操作系统有关。例如在安卓开发中,安卓的应用层是 JAVA API,而底层是 C 语言,JNI 技术中可以使用 Java 语言去调用 C 语言实现结构调用执行,从而提高程序执行的效率

这些部分共同构成了 JVM 的内存结构,负责存储和管理 Java 程序运行所需的数据和信息。

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值