java虚拟机内存划分

java虚拟机内存区域

参照官方文档 1.8版本

Oracle虚拟机内存划分文档 : https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-2.html#jvms-2.5

The Java Virtual Machine defines various run-time data
areas that are used during execution of a program.
Some of these data areas are created on Java Virtual
Machine start-up and are destroyed only when the Java
Virtual Machine exits. Other data areas are per thread.
Per-thread data areas are created when a thread is created
and destroyed when the thread exits.

大概意思就是:Java虚拟机定义了在程序执行期间使用的各种运行
时数据区域。其中一些数据区域是在Java虚拟机启动时创建的(例如堆、方法区),仅
在Java虚拟机退出时销毁。其他数据区域是每个线程。线程数据区
域是在线程退出时创建和销毁线程时创建的(虚拟机栈、本地方法栈、程序计数器)。

The pc Register(程序计数器或者pc寄存器):
    程序计数器是线程私有的,如果线程执行的不是native
    方法,则它保存的是当前虚拟机执行的java指令地址。
    如果是native方法,则它的值未定义
Java Virtual Machine Stacks(虚拟机栈或者“C stacks(C 栈)”):
    它随线程的创建而创建,它主要用来保存栈帧,
    栈帧主要用来保存局部变量、并在方法调用和返回结果中起作用,栈帧可以被分配在堆上,它的内存空间是不需要连续的。

    栈的大小可以人为设定。
    当计算的栈空间大于实际的栈空间的时候
    会抛出StackOverflowError。
    当栈需要进行扩容的时候,所剩的内存空间不满足扩容所需的大小的时候,
    或者内存不足以为新线程创建栈,会抛出OutOfMemoryError。
Heap(堆):
    堆是线程共享的数据区域、它是运行时数据区、分配所有实
    例对象内存和数组的内存。
    堆在虚拟机启动的时候创建、堆的内存空间有垃圾收集器管理
    (垃圾收集器类型可以有程序员来指定、选择合适的收集器)
    。堆的内存也可以不连续。堆上的对象永远不会显示的释放、
    即使调用了System.gc()方法也不一定会进行垃圾回收。
    程序员可以指定堆的初始大小、最大值和最小值。

    如果计算所需要的堆内存+已用堆内存超过堆的最大内存、则
    会抛出OutOfMemoryError。
Method Area(方法区):
    方法区属于线程共享的区域,它用来存储虚拟机加载的类信息、常量等。虚拟机规范认为它在逻辑上面是堆的一部分。但是可以不在方法区上面进行垃圾收集。它上面的对象属于永远不会被回收的。

    它的大小同样可以由伟大的程序员来指定。
    当需要加载的类信息的内存大于可用的方法区的内存时候,
    他会抛出OutOfMemoryError。
Run-Time Constant Pool(运行时常量池):
    运行时常量池是从方法区中分配的。当虚拟机构建类和接口时
    将为类和接口创建运行时常量池。
    在创建类或接口时,如果运行时常量池的构造需要的内存比Java虚拟机的方法区域中可用的内存多,则会抛出一个OutOfMemoryError。
Native Method Stacks(本地方法栈):
    本地方法栈和虚拟机栈作用差不多、只不过一个用来执行native方法、一个用来执行外部方法。

以上就是虚拟机的内存区划分及其大致作用。

下一篇将总结一下内存 区域中常用的一些名词,例如栈帧、局部变量等。

原文地址:https://www.cnblogs.com/evildoerdb/p/10415942.html

时间: 2024-10-10 15:48:26

java虚拟机内存划分的相关文章

Java虚拟机内存管理机制

自动内存管理机制 Java虚拟机(JVM)在执行Java程序过程中会把它所管理的内存划分为若干个不同的数据区域.这些区域都有各自的用途,以及创建和销毁的时间,有的区域随着虚拟机进程的启动而存在,有的区域则是依赖用户线程的启动和结束而建立和销毁.根据<Java虚拟机规范 第2版>规定,运行时数据区包括: 1.程序计数器 一块较小的内存空间,不在Ram上,而是直接划分在CPU上的,程序员无法直接操作它.当前线程所执行的字节码的行号指示器,通过改变这个计数器的值来选取下一条需要执行的字节码指令.每条

Java虚拟机内存模型及垃圾回收监控调优

Java虚拟机内存模型及垃圾回收监控调优 如果你想理解Java垃圾回收如果工作,那么理解JVM的内存模型就显的非常重要.今天我们就来看看JVM内存的各不同部分及如果监控和实现垃圾回收调优. JVM内存模型         正如你上图所看到的,JVM内存可以划分为不同的部分,广义上,JVM堆内存可以划分为两部分:年轻代和老年代(Young Generation and Old Generation) 年轻代(Young Generation) 年轻代用于存放由new所生成的对象.当年轻代空间满时,

JAVA虚拟机内存分配与回收机制

Java虚拟机(Java Virtual Machine) 简称JVM Java虚拟机是一个想象中的机器,在实际的计算机上通过软件模拟来实现.Java虚拟机有自己想象中的硬件,如处理器.堆栈.寄存器等,还具有相应的指令系统. Java把内存划分成两种:一种是栈内存,一种是堆内存. 在函数中定义的一些基本类型的变量和对象的引用变量都在函数的栈内存中分配. 当在一段代码块定义一个变量时,Java就在栈中为这个变量分配内存空间,当超过变量的作用域后,Java会自动释放掉为该变量所分配的内存空间,该内存

JVM——java虚拟机内存结构简介

JAVA虚拟机内存结构示意图 各区域介绍 程序计数器 程序计数器,用来记录每一个线程正在执行的指令地址.每一个线程有一个线程计数器,因此该区域是"线程私有"的内存,生命周期与线程相同.如果线程执行的是native本地方法,则程序计数器为空. 虚拟机栈区 每当线程执行一个方法时,虚拟机就会在这个区域创建一个栈帧,用于存储局部变量.动态链接.方法出口等信息.该区域也是"线程私有"的内存. 本地方法栈 本地方法栈主要是用来执行Native方法服务的 Java堆 所有线程共

java虚拟机---内存

java虚拟机---内存 Java虚拟机,即JVM,负责运行java程序,每个java程序都运行在一个具体jvm实例上.Java虚拟机的体系架构分为:类装载子系统.运行时数据区.执行引擎.类装载子系统即负责加载.验证.解析.初始化java类的系统:Java虚拟机在运行一个程序时需要储存很多数据,如类装载信息.创建的实例对象.方法调用的参数.局部变量.中间值等,虚拟机把这些信息都储存在"运行时数据区"里,即这里讲的JVM内存:执行引擎则是以字节码形式的class文件为输入,运行程序输出计

如何设置Java虚拟机内存以适应大程序的装载

Java虚拟机对于运行时的程序所占内存是有限制的,当我们的项目或者程序很大时,往往会照成内存溢出. 举个例子: public class SmallTest1 { public static void main(String[] args) { byte[] array = new byte[1024*1024*500]; } } 当定义这样一个500MB的数组时,就会造成JVM内存溢出: 而Java虚拟机默认的程序运行能得到的内存大小是随系统的,由Java的api体系结构中,点击Java: 后

Java虚拟机内存分配详解

简介 了解Java虚拟机内存分布的好处 1.了解Java内存管理的细节,有助于程序员编写出性能更好的程序.比如,在新的线程创建时,JVM会为每个线程创建一个专属的栈 (stack),其栈是先进后出的数据结构,这种方式的特点,让程序员编程时,必须特别注意递归方法要尽量少使用,另外栈的大小也有一定的限制,如果过多 的递归,容易导致stack overflow. 2.了解Java内存管理的细节,一旦内存管理出现问题,有助于找到问题的根本原因所在. 3.了解Java内存管理的内幕,有助于优化JVM,从而

【转】java虚拟机内存原型

本文主要通过分析Java内存分配的栈.堆以以及常量池详细的讲解了其的工作原理. 一.java虚拟机内存原型 寄存器:我们在程序中无法控制栈:存放基本类型的数据和对象的引用,但对象本身不存放在栈中,而是存放在堆中堆:存放用new产生的数据静态域:存放在对象中用static定义的静态成员常量池:存放常量非RAM存储:硬盘等永久存储空间. 二.常量池(constant pool) 常量池指的是在编译期被确定,并被保存在已编译的.class文件中的一些数据.除了包含代码中所定义的各种基本类型(如int.

Java虚拟机内存区域详解

众所周知,Java程序运行于Java虚拟机(JVM)上,那么,JVM运行的时候内存是如何分配的呢?程序中各部分变量都存储在内存的哪个部分,又如何访问,下面,就让我来给大家讲解Java虚拟机内存区域. 为什么需要了解Java虚拟机内存区域 相对于C++程序员,因为虚拟机的自动内存管理机制的存在,Java程序员很多时候并不需要去担心内存的泄露和内存溢出的问题.但是正是因为把内存的控制权交给了JVM,一旦出现内存泄露和溢出的问题,如果不了解虚拟机怎么使用内存,就很难排查错误. 内存泄露:一些对象在使用