高级工程师---JVM第二期

问题1:垃圾回收策略?
答: 1.引用基数:原理是此对象有一个引用就增加一个计数,删除一个引用就减少一个计数。致命的是无法处理循环
引用的问题。
2.标记清除:第一阶段,从引用根节点开始标记所有被引用的对象
第二阶段,遍历整个堆,把未标记的对象清除
缺点:需要暂停整个应用,同时产生内存碎片
3.复制:内存划分为两个相等的区域,每次只使用一个区域,垃圾回收时,遍历当前使用区域,把正在使用的对
象复制到另一个区域,复制成本小,且可进行内存整理
缺点:需要双倍内存空间
4.标记整理:第一阶段,从根节点开始标记所有被引用的对象
第二阶段,遍历整个堆,压缩未标记对象到堆的其中一块,按顺序排放
优点:避免复制算法的浪费空间,也避免内存碎片
补充:引用根节点指的是栈与静态变量寄存器之类的。最简单的java栈就是java程序执行的main函数--标记清除


问题2:分代?
答: 1.分代(年轻代,老年代,永久代)是基于不同对象的生命周期不同,为了提高回收的效率(socket,session这种对象周期很长,String这种不可变对象基本用一次就不用了)(标记整理)。
2.年轻代:一个Eden区,两个Survivor区。大部分对象在Eden区生成。当Eden区满,还存活的对象被复制到一
个Survivor区,当这个Survivor区也满了,此区对象被复制到另一个Survivor中,当这个Survivor也满
了,从第一个Survivor复制过来的对象依旧存活的,就转入老年代。两个Surivor部分前后两个Survivor
总有一个是空的。新对象生成申请空间失败时,触发Scavenge GC ,清理Eden到survivor,存活的
survivor复制到老年代(标记清除算法)
3.老年代: 经过多次垃圾回收后依旧存活的对象,什么周期长的对象,比如session,线程之类的(full GC)
4.永久代:静态文件,java类,方法之类的,一般堆垃圾回收影响不大,但是动态调用会生成新class,比如
hibernate,需要调大老年代(full GC标记清除算法)
---------------------------------------------------------------------------------------------------------------------------------------------------------问题3:垃圾收集算法
答: 1.串行垃圾收集器线程:单处理器机器(很少了现在),数据量小的情况下(100m),可使用-
XX:+UseSericalGC打开
2.并行垃圾收集器线程:多核心机器,不设置老年代手机还是单线程的,使用-XX:+UseParallelOldGC打开
缺点:响应时间加长
3.并发垃圾收集器:对时间响应敏感的大规模应用,使用-XX:+UseConcMarkSweepGC打开,主要用于减
少老年代暂停时间
缺点:在应用云信的同时进行垃圾回收,会有浮动垃圾产生,所以需要预留百分之二十的空间暂存这些垃圾。
总结:小破机器用串行垃圾收集器,吞吐量为重的用并行,时间敏感的用并发
补充:吞吐量=执行用户代码时间/总时间

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • JVM架构 当一个程序启动之前,它的class会被类装载器装入方法区(Permanent区),执行引擎读取方法区的...
    cocohaifang阅读 1,739评论 0 7
  • 转载blog.csdn.net/ning109314/article/details/10411495/ JVM工...
    forever_smile阅读 5,437评论 1 56
  • Java 虚拟机有自己完善的硬件架构, 如处理器、堆栈、寄存器等,还具有相应的指令系统。JVM 屏蔽了与具体操作系...
    尹小凯阅读 1,713评论 0 10
  • 内存溢出和内存泄漏的区别 内存溢出:out of memory,是指程序在申请内存时,没有足够的内存空间供其使用,...
    Aimerwhy阅读 766评论 0 1
  • Java和C++之间有一堵由内存动态分配和垃圾收集技术所围成的“高墙”,墙外面的人想进来,墙里面的人想出来。 对象...
    胡二囧阅读 1,153评论 0 4