JVM内存空间
来源:互联网 发布:java门户网站源码下载 编辑:程序博客网 时间:2024/05/29 06:50
大多数 JVM 将内存区域划分为 Method Area(Non-Heap)(方法区) ,Heap(堆) , Program Counter Register(程序计数器) , VM Stack(虚拟机栈,也有翻译成JAVA 方法栈的),Native Method Stack ( 本地方法栈 ),其中Method Area 和 Heap 是线程共享的 ,VM Stack,Native Method Stack 和Program Counter Register 是非线程共享的。为什么分为 线程共享和非线程共享的呢?请继续往下看。
首先我们熟悉一下一个一般性的 Java 程序的工作过程。一个 Java 源程序文件,会被编译为字节码文件(以 class 为扩展名),每个java程序都需要运行在自己的JVM上,然后告知 JVM 程序的运行入口,再被 JVM 通过字节码解释器加载运行。那么程序开始运行后,都是如何涉及到各内存区域的呢?
概括地说来,JVM初始运行的时候都会分配好 Method Area(方法区) 和Heap(堆) ,而JVM 每遇到一个线程,就为其分配一个 Program Counter Register(程序计数器) , VM Stack(虚拟机栈)和Native Method Stack (本地方法栈), 当线程终止时,三者(虚拟机栈,本地方法栈和程序计数器)所占用的内存空间也会被释放掉。这也是为什么我把内存区域分为线程共享和非线程共享的原因,非线程共享的那三个区域的生命周期与所属线程相同,而线程共享的区域与JAVA程序运行的生命周期相同,所以这也是系统垃圾回收的场所只发生在线程共享的区域(实际上对大部分虚拟机来说知发生在Heap上)的原因。
方法区在JVM中也是一个非常重要的区域,它与堆一样,是被 线程共享 的区域。 在方法区中,存储了每个类的信息(包括类的名称、方法信息、字段信息)、静态变量、常量以及编译器编译后的代码等。
参考
- JVM内存空间
- JVM内存空间学习
- JVM内存空间管理
- JVM内存空间总结
- jvm内存管理 1 内存空间
- JVM运行时内存空间结构
- jvm的内存空间分块情况
- JVM 内存空间分为几部分
- 细说JVM系列:JVM内存空间分区
- jvm内存空间新对象申请活动图
- Jvm内存空间结构是什么样的?
- Jvm内存空间结构是什么样的?
- 内存空间
- 内存空间
- 内存空间
- 由JVM内存空间想到的java编码规范
- JVM基础(一):内存空间分配及其回收原理
- JVM执行Java程序的过程中管理的内存空间
- 5月英语总结—平淡不平凡
- laravel(五)-laravel中的数据库原始查找
- Linux下的读写锁
- 32C3-CTF README
- Docker
- JVM内存空间
- 2017前端校招
- 医疗界的大数据信息是否也能“共享”
- 基于链表的方法实现静态内存管理
- 7153
- 树莓派的使用+linux命令2
- Problem A: 时间类的构造和输出
- 问题 C: 最小秘钥
- HDFS高可用原理,个人理解嘿嘿嘿