自己总结-jvm面试点

  • jvm内存模型
    1.线程共享:堆内存+方法区
    2.线程私有:虚拟机栈+本地方法栈+程序计数器
    堆内存主要存储java实例对象,分为新生代和老年代,新生代又分为eden、survivor from、survivor to,三者的内存分比默认为8:1:1,对象创建首先会分配到eden区,eden区内存满了之后进行Minor GC,将满足存活条件的对象复制到survivor from区,第二次Minor GC会将满足存活条件的对象复制到survivor to区,依次类推默认15次之后,如果该对象依然满足存活条件,会将该对象复制到老年代。
    方法区:主要存储加类的类信息,常量,静态变量等。
    虚拟机栈:每个线程都对应一个虚拟机栈,每个虚拟机栈都会创建一个栈帧,栈帧里主要存储局部变量表,操作数栈,动态链接和方法出口。
    本地方法栈:用于native方法的调用,存储了本地方法的状态。
    程序计数器:只记录当前指令的地址
  • jvm垃圾回收算法
    1.标记-清除算法
    缺点:标记和清除都需要遍历内存空间,容易产生空间碎片,如果内存碎片过多,没有大块的内存会导致full gc
    2.复制算法
    优点:与标记-清除算法相比,不用遍历内存空间,效率较高,不会产生空间碎片
    缺点:会将内存分为两半,内存使用率较低
    优化:仅在新生代使用复制算法,并且eden:from:to=8:1:1,提高了内存使用率
    3.标记-整理算法
    当对象存活率较高或者对象较大时,复制算法的意义不大,所以针对老年代提出了标记整理算法,先对需要回收的对象进行标记,存活的对象向内存的一端移动,然后直接清理掉没有用的内存。
    4.分代收集算法
    根据新生代和老年代的不同特点,采用不同的垃圾回收算法
  • 常用的垃圾收集器:
    1.Serial (串行gc)复制算法
    2.ParNew(并行gc) 复制算法
    3.Parallel Scavenge (并行gc)复制算法
    4.Serial Old (串行gc)标记-整理算法
    5.CMS (并行gc)标记-清除算法
    6.Parallel Old (并行gc)标记-整理算法
    7.G1
    1,2,3是针对新生代的垃圾收集器,4,5,6是针对老年代的垃圾收集器,G1可以独立完成分代回收
    比较高效的组合:ParNew+CMS
    CMS的缺点:使用标记-清除算法,容易产生内存碎片
    G1的运行机制:
    (1)初始标记
    (2)并发标记
    (3)最终标记
    (4)筛选回收
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值