一窥JAVA内存区域

JAVA内存区域

1Hotspot JVM

Hotspot JVM中的 Java 线程与原生操作系统线程有直接的映射关系。当线程本地存储、缓冲区分配、同步对象、栈、程序计数器等准备好以后,就会创建一个操作系统原生线程。当原生线程初始化完毕,就会调用 Java 线程的 run() 方法。Java 线程结束,原生线程随之被回收。

虚拟机线程

该线程等待JVM到达安全点操作:垃圾回收,线程栈,线程暂停,偏向锁解除

周期性任务线程

负责定时器事件(也就是中断),用来调度周期性操作的执行。

GC 线程

这些线程支持 JVM 中不同的垃圾回收活动。

编译器线程

这些线程在运行时将字节码动态编译成本地平台相关的机器码。

信号分发线程

这个线程接收发送到 JVM 的信号并调用适当的 JVM 方法处理。

2JVM 内存区域

蓝色区域:线程私有区域,线程私有数据区域生命周期与线程相同, 依赖用户线程的启动/结束 创建/销毁(HotspotVM , 每个线程都与操作系统的本地线程直接映射, 这部分内存区域的存/否跟随本地线程的生/死对应)

黄色会线程共享区域:线程共享区域随虚拟机的启动/关闭而创建/销毁

虚拟机栈:为执行Java 方法服务,存8大基本类型 + 对象引用 + 实例方法,每个方法在执行的同时都会创建一个栈帧用于存储局部变量表、操作数栈、动态链接、方法出口等信息。每一个方法从调用直至执行完成的过程,就对应着一个栈帧在虚拟机栈中入栈到出栈的过程。

程序计数器:每个线程启动是都会创建一个程序计数W器,保存的是虚拟机字节码指令的地址,程序计数器总是指向下一条将被执行指令的地址

本地方法区:Native 方法服务

方法区(永久代):存储被JVM 加载的类信息、方法信息、常量、静态变量、运行时常量池。

堆:创建的对象和数组都保存在Java 堆内存中,也是垃圾收集器进行垃圾收集的最重要的内存区域。从GC角度,可以分为新生代(用来存放新生的对象,会频繁触发MinorGC 进行垃圾回收)和老年代(存放应用程序中生命周期长的内存对象)

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值