JVM之Java内存区域

JVM之Java内存区域

    Java虚拟机在执行Java程序时会把它所管理的内存划分为若干个不同的数据区域;每个区域都会有各自不同的用途,创建销毁的时间也不尽相同,有的区域随着虚拟机进程启动而存在,有的则依赖用户进线程的启动结束而建立销毁;虚拟机管理的内存包含下列几个运行时数据区域;如下图所示:
Java运行时数据区

程序计数器(线程私有)

    程序计数器(Program Counter Register)是一块较小的内存空间,可以看做是当前线程所执行的字节码行号指示器。
为什么需要程序计数器?
    由于Java虚拟机的多线程是通过线程轮流切换并分配处理器执行时间的方式来实现的,在任何一个确定的时刻,一个处理器(对于多核处理器来说是一个内核)都只会执行一条线程中的命令。因此,为了线程切换后能回复到正确的执行位置,每条线程都需要一个独立的程序计数器,以至于线程之间互不影响,独立存储;

Java虚拟机栈(线程私有)

    虚拟机栈描述的是Java方法执行的内存模型:每个方法在执行的同时都会创建一个栈帧(Stack Frame)用于存储局部变量表、操作数栈、动态链接、方法出入口等信息。每个方法从调用到执行完成的过程,都会对应一个栈帧从入栈到出栈的过程;
    局部变量表存放了编译期可知的各种基本数据类型(8大基本数据类型)、对象引用类型(可能是指向对象的引用指针,也可能是代表对象的的句柄或者其它与此对象有关的位置)和returnAddress类型(指向了一条字节码指令的地址)。
    两种异常情况:在虚拟机规范中对这个区域定义了两种异常情况:
        1.如果线程请求的栈深度大于虚拟机允许的深度,将会抛出StackOverFlowError异常;
        2.如果虚拟机可以动态拓展(虚拟机规范中允许固定长度的虚拟机栈也允许动态拓展),但是在拓展时无法申请到足够的内存,就会抛出OutOfMemoryError异常

本地方法栈(线程私有)

    本地方法栈(Native Method Stack)与Java虚拟机栈的作用非常相似,区别在于Java虚拟机栈为虚拟机执行Java方法服务,而本地方法栈则为虚拟机使用到的Native方法服务。

Java堆(线程共享)

    Java堆(Java Heap)是Java虚拟机中所管理的内存中最大的,在虚拟机启动时创建;用于存放对象实例,几乎所有的对象实例都存放在这里,也是垃圾收集器管理的主要区域;根据Java虚拟机规范的规定,Java堆可以存放在不连续的空间中,只要逻辑上是连续的即可。大小可通过-Xms和-Xmx控制;

方法区(线程共享)

    方法区(Method Area)被用于存储已被虚拟机加载的类信息(类名、访问修饰符、字段描述、方法描述)、常量、静态变量、即时编译器编译后的代码等数据。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值