jvm内存区域

  

                图1 Java虚拟机运行时数据区

1、程序计数器

  一块较小的内存空间,字节码解释器工作时就是通过这个计数器的值来取下一跳需要执行的字节码指令,分支、循环、跳转、异常处理、线程恢复等基础功能都要依赖这个计数器来完成。每个线程都需要一个独立的程序计数器,为了多线程切换后能恢复到正确的执行位置。执行一个Java方法,计数器记录的是正在执行的虚拟机字节码指令的地址。“线程私有”的。

2、Java虚拟机栈

  生命周期与线程相同。描述的是Java方法执行的内存模型:每个方法再执行的同时都会创建一个栈帧用于存储局部变量表、操作数栈、动态链接、方法出口等信息。每一个方法从调用直至执行完成的过程,就对应着一个栈帧在虚拟机栈中入栈到出栈的过程。"线程私有“的。

3、本地方法栈

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

4、Jav堆

  虚拟机启动时创建,目的是存放对象实例,几乎所有的对象实例都在这里分配内存。Java堆是垃圾收集器管理的主要区域,也被称做“GC”堆,Java堆还可以细分为新生代和老年代。Java堆可以处在物理上不连续的内存空间中,只要逻辑上是连续的即可。“线程共享”的。

5、方法区

  用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据,和Java堆一样不需要连续的内存和可以选择固定大小或者可扩展。

6、运行常量池

  是方法区的一部分,用于存放编译器生成的各种字面量和符号引用,这部分内容将在类加载后进入方法区的运行时常量池中存放。

7、直接内存

  并不是虚拟机运行时数据区的一部分,但是这部分内存也被频繁地使用,而且也可能导致OutOfMemoryError异常出现。
在JDK1.4中新加入了NIO(NewInput/Output)类,引入了一种基于通道(Channel)与缓冲区(Buffer)的I/O方式,它可以使用Native函数库直接分配堆外内存,然后通过一个存储在Java堆里面的DirectByteBuffer对象作为这块内存的引用进行操作。这样能在一些场景中显著提高性能,因为避免了在Java堆和Native堆中来回复制数据。
显然,本机直接内存的分配不会受到Java堆大小的限制,但是,既然是内存,则肯定还是会受到本机总内存(包括RAM及SWAP区或者分页文件)的大小及处理器寻址空间的限制。服务器管理员配置虚拟机参数时,经常会忽略掉直接内存,使得各个内存区域的总和大于物理内存限制(包括物理上的和操作系统级的限制),从而导致动态扩展时出现OutOfMemoryError异常。

 

  

6、运行常量池
[6, Yùnxíng chángliàng chí]
6, run the constant pool
posted @ 2020-05-11 16:12  我们村里的小花儿  阅读(107)  评论(0编辑  收藏  举报