性能分析调优-JVM基础:堆、栈、元空间

Java内存管理机制

  • Java采用了自动管理内存的方式
  • Java程序是运行在Jvm之中的
  • Java的跨平台的基于Jvm的跨平台特性
  • 内存的分配和对象的创建是在Jvm中
  • 用户可以通过一系列参数来配置Jvm

JVM运行时区域

栈内存

  • 线程私有 - 每个线程有自己独立的栈内存,比较小,单位通常是kb,最多1M
  • 生命周期和线程相同
  • 主要存放变量(基本类型和对象类型)
    • 基本数据类型(int,charfloat,double...)
    • 对象的引用,指向了对象在堆内存中的起始地址 -- 栈区比较小,所以只是存放对象的地址,对象的真正的的数据存放在堆区中
  • 通过-Xss参数配置 

堆内存(Heap Memory

  • 堆内存是Jvm中空间最大的区域
  • 所有线程共享堆
  • 所有的数组以及内存对象的实例都在此区域分配 - 大量的数据都在堆内存中。
    • 例如:Cat c = new Cat(),其中c作为对象的引用/地址,存放在栈内存,new Cat(),对象的实例,存放在堆区。
  • 堆内存大小通过参数进行配置
    • -Xmx:最大堆内存
    • -Xms:最小堆内存

因为堆占用内存空间最大,堆也是Java垃圾回收的主要区域(重点对象),因此也称作“GC堆”(Garbage Collected Heap)

  1. 堆内存=年轻代+老年代
  2. 年轻代=Eden+Survivor
  3. Survivor = From Space(s0)+To Space(s1),From 和 To 是交替的。

1.堆内存的工作机制

(1)对象分配流程
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值