JVM 内存管理

内存结构图


内存结构图

    针对上图,内存指的就是上图运行时数据区(RUNTIME DATA AREA)这部分。

Method Area (方法区)

    方法区是全局共享的。
    方法区主要存储的是 运行时常量池(jdk1.7以后移除了字符串常量池?)、字段信息构造方法以及普通函数的字节码内容以及特殊方法
    与堆还有一个区别在于,java虚拟机不强制要求这个区域进行gc。
    大部分人喜欢将方法区称之为“永久代”。实际上这两个概念是不想等的。我的理解是:永久代是虚拟机中的一个概念,而因为Hotspot使用永久代来实现方法区,所以针对于Hotspot虚拟机来说可以这么讲,有些其他虚拟机是没有永久代这个概念的。

Heap(堆)

    堆也是全局共享的。
    它随着虚拟机的启动创建,存储着所有对象实例以及数组对象。是gc主要针对的区域。
    根据Java虚拟机规范的规定,Java堆可以处于物理上不连续的内存空间,只要逻辑上连续即可。

JavaStack (栈/虚拟机栈/堆栈)

    栈是线程私有的。
    Java栈是在创建线程的同时创建的,用于存储栈帧。
    每个方法执行的时候都会创建同时创建一个栈帧,用于存储局部变量表、操作栈、动态连接、方法出口等信息。也就是这些都是存在栈帧里面的。
    下图描述的是这个例子(灵魂画手哈哈哈):假设现在执行一个方法,那么会创建一个栈帧1,压入栈底(默认为本地变量表),在这个方法中发现又调用了另外一个方法,那么就又创建了一个栈帧2,压入栈。当方法2执行完毕后,栈帧2出栈,销毁,继续执行方法1。当方法1执行完毕,出栈,销毁。。
灵魂画手

  • 局部变量表
      局部变量表存放了编译器可知的各类基本数据类型(int,byte,double…),对象引用类型,returnAddress类型。它是一个方法局部变量的列表,是在编译器就写入class文件中的
  • 操作栈
      它是一个后进先出栈,它的长度也是编译时期就写入了class文件中,是固定的。它的作用就是提供字节码指令,计算操作变量的空间。

Program Counter Register(程序计数器)

    它是一个程序记载着每一个线程当前运行的Java方法地址,如果执行的是本地方法那么就是一个空地址。
    作用是用于支持多线程,线程的阻塞/恢复/挂起等一系列操作。所以基于这一点,程序计数器也是线程私有的。

Native Method Stack(本地方法栈)

    本地方法栈也是线程私有的。
    和栈的区别是本地方法栈为虚拟机使用到的native方法服务。

对于线程私有的这部分内存,都是随着线程的启动而创建,线程的结束而释放。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值