JVM运行时数据区域划分

运行时数据区包括:程序计数器、虚拟机栈、本地方法栈、Java堆、方法区以及方法区中的运行时常量池

  1. 程序计数器:
    线程私有,是当前线程所执行的字节码的行号指示器,如果线程正执行一个java方法,计数器记录正在执行的虚拟机字节码指令的地址,如果线程正在执行的是Native方法,则计数器值为空;

  2. 虚拟机栈:
    即栈区,线程私有,为虚拟机执行Java方法(字节码)服务,每个方法在执行的时会创建一个栈帧用于存放局部变量表、操作数栈、动态链接和方法出口等信息,每个方法的调用直至执行完成对应于栈帧的入栈和出栈;

  3. 本地方法栈:
    为虚拟机使用的Native方法服务,也是线程私有的;

  4. Java 堆:
    在虚拟机启动时创建,线程共享,唯一目的是存放对象实例,是垃圾收集器管理的主要区域——”GC堆“,可以细分为新生代和老年代,新生代又可以细分为Eden空间、From Survivor空间和To Survivor空间;物理上可以不连续,但逻辑上连续,可以选择固定大小或者扩展;

  5. 方法区:
    线程共享,用于存储被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。被称为“永久代”,是因为HotSpot虚拟机的设计团队把GC分代收集扩展到方法区,即使用永久代来实现方法区,像GC管理Java堆一样管理方法区,从而省去专门为方法区编写内存管理代码,内存回收目标是针对常量池的回收和堆类型的卸载;

  6. 运行时常量池:
    线程共享,是方法区的一部分,Class文件中存放编译期生成的各种字面量和符号引用,类加载后进入方法区的运行时常量池中。

关于Java中的堆和栈,简单来说,基本数据类型变量和对象的引用都是在栈分配的,堆内存用来存放由new创建的对象和数组。
类变量,程序在一加载的时候就在堆中为类变量分配内存,堆中的内存地址存放在栈中。
实例变量,使用java关键字new的时候,系统在堆中开辟并不一定是连续的空间分配给变量,根据零散的堆内存地址,通过哈希算法换算为一长串数字以表征这个变量在堆中的”物理位置”,实例变量的生命周期–当实例变量的引用丢失后,将被GC列入可回收名单中,但并不是马上就释放堆中内存,释放时间由垃圾回收算法决定。
局部变量,声明在某方法或某代码段里(比如for循环),执行到它的时候在栈中开辟内存,当局部变量一但脱离作用域,内存立即释放。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值