博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JAVA GC 简单总结
阅读量:4291 次
发布时间:2019-05-27

本文共 782 字,大约阅读时间需要 2 分钟。

GC分代

GC的英文全拼是Garbage Collection,意思是垃圾收集。

Java 将堆内存分为三代来管理: - 年轻代 (Young Generation) - 年老代 (Old Generation) - 永久代 (Perm Generation)

年轻代:又分为EdenFromTo,其中FromTo又统称为Survivor Spaces(幸存区)。年轻代大小可以由-Xmn来控制,也可以用-XX:SurvivorRatio来控制EdenSurvivor的比例,使用–XX:NewRatio来指定新生代和年老代的大小比例。

年老代:用来存放多次垃圾回收依然存活的对象。

永久代:来存放方法区。可通过-XX:PermSize-XX:MaxPermSize来指定最小值和最大值。

正常情况下,一个对象从创建到销毁,应该是从Eden,然后到Survivor Spaces(幸存区),再到Old Generation(年老代),最后在某次GC下消失。也可能一个对象直接在Eden里死掉,也可能一直在Old Generation(年老代)存活。

GC种类

Java GC分为两类:

  • Minar GC
  • FULL GC
  • Major GC

Minar GC:从年轻代空间(包括 EdenSurvivor区域)回收内存被称为 Minor GC。

Major GC:是清理老年代。

FULL GC:是清理整个堆空间—包括年轻代和老年代。

GC的时候,会暂停全世界(stop-the-world),意思是停止所有的应用线程,所以要避免不必要的GC已提高性能。

GC日志

-XX:+PrintGCDetails打印日志详情。

-XX:+PrintGCTimeStamps打印时间戳。

-Xloggc输出GC日志到文件。

转载地址:http://bxggi.baihongyu.com/

你可能感兴趣的文章
javascript设计模式-工厂模式(4)
查看>>
javascript设计模式-组合模式(6)
查看>>
javascript设计模式-门面模式(7)
查看>>
javascript设计模式-享元模式(10)
查看>>
javascript设计模式-代理模式(11)
查看>>
Executor相关源码分析
查看>>
react之setState解析
查看>>
elasticsearch7.3版本已经不需要额外安装中文分词插件了
查看>>
【重大好消息】elasticsearch 7.3版本已经可以免费使用x-pack就可以设置账号和密码了,让你的数据不再裸奔
查看>>
解决使用logstash中jdbc导入mysql中的数据到elasticsearch中tinyint类型被转成布尔型的问题的方法
查看>>
elasticsearch7.3版本环境搭建(一)elasticsearch安装和配置
查看>>
SEO基本功:站内优化的一些基本手段
查看>>
centos6系列和7系列如何对外开放80,3306端口号或者其他端口号
查看>>
为什么您宁愿吃生活的苦,也不愿吃学习的苦?为什么你不愿意去学习呢
查看>>
解决elasticsearch7.3版本安装过程中遇到的包括内存不够、线程不够等问题
查看>>
日常项目测试用例检查点(来自一线测试人员的吐血总结)
查看>>
网站建设之域名注册和域名备案
查看>>
解决bootstrap时间输入框总被浏览器记住的记录遮挡住的问题
查看>>
git将一个分支完全覆盖另外一个分支如:dev分支代码完全覆盖某一个开发分支
查看>>
elasticsearch7.3版本环境搭建(二)可视化管理后台kibana的安装和配置
查看>>