JVM内存模型
Posted 128-cdy
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JVM内存模型相关的知识,希望对你有一定的参考价值。
JVM的内存划分:
方法区:是线程共享的,常量静态变量的JIT(即时编译器)编译后代码也在方法区存放。用来存储已被虚拟机加载的类信息,常量,静态变量,即时编译器编译后的代码等数据。虽然Java虚拟机规范把方法区描述为堆得一个逻辑部分,但是他却有个别名Non-Heap(非堆),目的是为了与Java堆区分。
堆内存:是线程共享的,垃圾回收的主要场所。Java虚拟机所管理的内存最大的一块,在虚拟机启动时创建。此内存区域的唯一目的就是存放对象实例(也就是new出来的),几乎所有的对象实例以及数组都在这里分配。Java堆是垃圾收集管理器的主要区域,因此也被称作GC堆。
程序计数器:当前线程执行的字节码的位置指示器。是一块较小的内存空间,可以看做是当前线程所执行的符号指示器。
两个主要作用:
- 字节码解释器通过改变程序计数器来一次读取指令,从而实现代码的流程控制,如:顺序执行,选择,循环,异常处理。
- 在多线程的情况下,程序计数器用于记录当前程序执行的位置,从而当线程被切换回来的时候能够知道该线程上次运行的位置。
注意:程序计数器是唯一一个不会出现OutOfMemoryError的内存区域,他的生命周期随着现成的创建而创建,随着线程的结束而死亡。
Java虚拟机(栈内存):保存局部变量,基本数据类型以及堆内存中对象的引用变量。是线程私有的,每个线程都有各自的Java虚拟机栈,并且随着线程的创建而创建,随着线程的死亡而死亡。
Java虚拟机会出现两种异常:StackOverFlowError和OutOfMemeoryError
- StackOverFlowError的异常:若Java虚拟机栈的内存大小不允许动态扩展,当线程请求栈的深度超过当前Java虚拟机栈的最大深度的时候,就会抛出该异常。
- OutOfMemeoryError的异常:若Java虚拟机的内存允许动态扩展,且当线程请求栈内存用完了,无法再动态扩展了,此时会抛出该异常。
本地方法栈:为JVM提供使用native方法的服务。与虚拟机栈发挥的作用非常相似。区别是虚拟机栈作为虚拟机执行Java方法(也就是字节码文件)的服务,而本地方法栈则为虚拟机使用到的native方法服务。也会抛出StackOverFlowError和OutOfMemeoryError的异常。
以上是关于JVM内存模型的主要内容,如果未能解决你的问题,请参考以下文章