java虚拟机内存模型

程序计数器:

1、它是当前线程所执行的字节码的行号指示器。

2、每个线程都有自己私有的程序计数器。

3、执行java方法时,记录的是正在执行的虚拟机字节码指令的地址;

执行native方法时,计数器的值为空。

4、此内存区域是jvm中唯一一个没有规定OutOfMemoryError的区域。

 

虚拟机栈:

1、每个方法执行的时候都会创建一个栈帧,用于存储局部变量表、操作数栈、动态链接、方法出口等信息。

2、局部变量表存储8种基本数据类型、对象引用和returnAddress类型(指向一条字节码指令的地址)。

3、局部变量表所需的内存空间在编译期间完成分配,当进入一个方法时,这个方法在栈中分配多大的局部变量空间是完全确定的,在方法运行期间不会改变局部变量表的大小。

4、long和double类型占2个局部变量空间(slot),其他类型占1个。

5、如果线程请求的栈深度大于虚拟机所允许的,抛出StackOverFlow异常。

如果可以动态扩展,但扩展时申请不到内存,抛出OutOfMemoryError。

 

本地方法栈:

1、与虚拟机栈类似,它记录虚拟机用到的native方法服务。

2、sun hotspot将本地方法栈和虚拟机栈合二为一。

 

java堆:

1、它是所有线程共享的一块内存区域,在虚拟机启动时创建。

2、它唯一的目的:存放对象实例。

3、如果在堆中没有内存再进行分配,且堆不能再进行扩展,则抛出OutOfMemoryError。

 

方法区:

1、它是各个线程共享的内存区域。

2、它用于存储已被虚拟机加载的类的信息、常量、静态变量、即时编译器编译后的代码等数据。

3、hotspot vm中这部分也被称为永久代(Permanent Generation)。

4、这个区域垃圾回收器也会进行回收,主要目标是常量池和对类型的卸载。

 

------------------------------------------------------------------------------------------------------------------------------

运行时常量池:

1、它是方法区的一部分。

2、它用来存放编译期生成的各种字面量和符号引用,以及运行时翻译出来的直接引用。

 

直接内存:

1、它并不是jvm内存区域的一部分。

2、它可以避免在java堆和native堆中来回复制数据,从而提高性能。使用时,可以使用native函数直接分配堆外内存,然后通过一个存储在java堆中的DirectByteBuffer对象作为这块直接内存的引用进行使用。

3、它不受java堆大小的限制,受本机总内存大小的限制。

 

 

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值