Java内存管理:Java内存区域 JVM运行时数据区
Java内存管理:Java内存区域 JVM运行时数据区 在前面的一些文章了解到javac编译的大体过程、Class文件结构、以及JVM字节码指令。 下面我们详细了解Java内存区域:先说明JVM规范定义的JVM运行时分配的数据区有哪些,然后分别介绍它们的特点,并指出给出一些HotSpot虚拟机实现的不同点和调整参数。 1、Java内存区域概述 1-2、C/C++与Java程序开发的内存管理 在内存管理领域,C/C++程序开发与Java程序开发有着完全不同的理念: 1、C/C++程序开发 自己管理内存是一项基础的工作; 自已分配内存,但也得自己来及时回收; 比较自由,但多了些工作量,且容易出现内存泄露和内存溢出等问题; 2、Java程序开发 JVM管理内存,不需要自己手动分配内存和释放内存; 不容易出现内存泄露和内存溢出; 一旦出现问题不容易排查,所以得了解JVM是怎么使用内存; 1-2、Java内存区域与JVM运行时数据区 如上图, Java虚拟机规范定义了字节码执行期间使用的各种 运行时数据区 ,即JVM在执行Java程序的过程中,会把它管理的内存划分为若干个不同的数据区域,包括: 程序计数器、java虚拟机栈、本地方法栈、java堆、方法区、运行时常量池; 从线程共享角度来说,可以分为两类: 1、所有线程共享的数据区 方法区、运行时常量池、java堆;