java 虚拟机内存介绍

已经入行快有两年了,然而没有认真看过java虚拟机内存的介绍,下面把自己看的关于java虚拟机内存的介绍写下来,分享给大家。

java 虚拟机在运行时将内存分为几个区域,分别为程序记数区,java虚拟机栈,本地方法栈,java堆,方法区,运行常量池。此外还有一个叫做直接内存的区域,虽然不是java虚拟机的一部分,但是也非常重要。

程序计数器

顾名思义就是记录当前线程执行的字节码的行号,由于java虚拟机中的多线程是通过多线程轮流切换来实现多线程的,为了线程在切换后能回复到正确的执行位置,每个线程都会有一个独立的计数器,各线程之间应该是互不影响的。所以,在程序计数器所占有的区域是线程私有的。

  • 如果当前线程执行的是java方法,那么程序计数器记录的是字节码的地址,如果执行的是native方法,计数器的值为空

Java虚拟机栈

java虚拟机栈是java方法执行的内存模型,每一个方法在执行时都换创建一个栈帧,用于存放局部变量表,操作数栈,动态链接,返回接口等信息。

我理解的是,当前在执行一个方法时先创建一个栈帧,如果在这个方法中调用了其他方法,那么当前的栈帧就会压栈,然后给调用的方法创建一个栈帧。这样依次类推。

  • 局部变量表中存放的编译器可知的数据类型,Boolean,byte,char,short等。对于方法中的对象,存储的是引用。
  • 可能抛出的异常:如果请求深度超过栈的最大深度,将会跑出StackOutOfFlow异常,如果线程在请求栈内存时,没有获得足够的内存,就会跑出OutOfMemery异常。

java堆

java堆是线程共享的区域,这里主要存储对象和数组的实例。垃圾回收也是主要在这一块内存上。

方法区

方法区是线程共享的区域,他主要用于存储虚拟机加载的类信息,常量,静态变量。

运行时常量池

他是方法区的一部分,用于存放编译器生成的各种字面常量和符号引用。

直接内存

这部分不是java虚拟机的内存,给予通道的缓冲区。存在于本机的内存中,不收java堆大小的限制,但如果太大,(加上虚拟机的内存超过本机内存时)也会报OutOfMemery异常。

时间: 2024-10-17 02:01:41

java 虚拟机内存介绍的相关文章

Java虚拟机内存管理机制

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

Java虚拟机内存区域详解

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

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

【转】java虚拟机内存原型

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

Java虚拟机内存模型和volatile型变量

Java虚拟机内存模型 了解Java虚拟机的内存模型,有助于我们明白为什么会发生线程安全问题. 上面这幅图是<深入理解Java虚拟机-JVM高级特性与最佳实践>的书中截图. 线程共享的变量会保存在主内存中(Main Memory). 而线程共享的变量的副本会保存在每个线程各自的工作内存中(Working Memory). 线程对于共享变量的所有操作(读取,赋值等)都必须在工作内存中进行,不能直接读写主内存的变量. 不同的线程之间,也无法访问其他线程的工作内存.线程之间的变量传递需要通过主内存来