【JVM】——内存模型

(一)总体架构图


(二)简介

  1. 程序计数器:当前线程执行的字节码的行号指示器。线程私有
  2. java虚拟机栈:线程私有。虚拟机栈描述的是虚拟机执行Java方法执行的内存模型:每个方法被执行的时会同时创建一个栈帧(Stack Frame ①)用于存储局部变量表、操作栈、动态链接、方法出口等信息。
    1. 局部变量表:存放编译期可知的基本数据类型(booleanbytecharshortintfloatlongdouble)、对象引用reference 类型
  1. 本地方法栈:线程私有。描述的是虚拟机使用到的Native方法服务。
  2. Java堆:所有线程共享的。虚拟机启动时创建。
    1. 目的:存放对象实例,几乎所有的对象实例都在这里分配内存。
    2. Java堆是垃圾收集器管理的主要区域。也称GC
      1. 收集器基本都采用分代收集算法。Java堆可分为新生代和老年代。
  3. 方法区
    1. 所有线程共享
    2. 用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据
  4. 运行时常量池
    1. 是方法区的一部分。Class 文件中除了有类的版本、字段、方法、接口等描述等信息外,还有一项信息是常量池(Constant PoolTable),用于存放编译期生成的各种字面量和符号引用,这部分内容将在类加载后存放到方法区的运行时常量池中。
  5. 直接内存:NIO可以使用Native函数库直接分配堆外内存,然后通过一个存储在Java 堆里面的DirectByteBuffer 对象作为这块内存的引用进行操作。这样能在一些场景中显著提高性能,因为避免了在Java 堆和Native 堆中来回复制数据。



评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值