垃圾收集

判断对象是否已死:

  1. 引用计数法(很难解决对象之间相互循环引用的问题)
  2. 可达性分析算法
  • 可作为GC Roots的对象包括:
    ① 虚拟机栈中引用的对象
    ② 方法去中类静态属性引用的对象
    ③ 方法区中常量引用的对象
    ④ 本地方法栈中JNI(Native方法)引用的对象

引用

  • 强引用
  • 软引用
  • 弱引用
  • 虚引用

回收区域

1. 方法区:回收性价比低

2. 堆(主要回收区域):

  • 新生代:Minor GC(复制算法)
  • 老年代:Major GC/Full GC(标记—整理算法)
  • 永久代:废弃常量和无用类
    • 无用类:
      ① 该类的所有实例已被回收
      ② 加载该类的ClassLoader已被回收
      ③ 该类对应的java.lang.Class对象没有在任何地方被引用,无法在任何地方通过反射访问该类

    • 内存的永久保存区域,主要存放Class和Meta(元数据)的信息,Class在被加载的时候被放入永久区域. 它和存放实例的区域不同,GC不会在主程序运行期对永久区域进行清理。所以这也导致了永久代的区域会随着加载的Class的增多而胀满,最终抛出Out of Memory异常。
      在Java8中,永久代已经被移除,被一个称为“元数据区”(元空间)的区域所取代。
      不过元空间与永久代之间最大的区别在于:元空间并不在虚拟机中,而是使用本地内存。因此,默认情况下,元空间的大小仅受本地内存限制。类的元数据放入 native memory, 字符串池和类的静态变量放入java堆中. 这样可以加载多少类的元数据就不再由MaxPermSize控制, 而由系统的实际可用空间来控制.
      采用元空间而不用永久代的几点原因:
      1、为了解决永久代的Out of Memory问题,元数据和class对象存在永久代中,容易出现性能问题和内存溢出。
      2、类及方法的信息等比较难确定其大小,因此对于永久代的大小指定比较困难,太小容易出现永久代溢出,太大则容易导致老年代溢出(因为堆空间有限,此消彼长)。
      3、永久代会为 GC 带来不必要的复杂度,并且回收效率偏低。
      4、Oracle 可能会将HotSpot 与 JRockit 合二为一。

垃圾收集算法

1. 标记—清除算法(最基本)

2. 复制算法(新生代)

  • 新生代分为:Eden和两个Survivor大小比例是8:1,回收时,将Eden和survivor中还存活的对象一次性的复制到另一个Survivor空间中 ,同时把这些对象的年龄+1(默认情况下15岁就直接送到老年代了),最后清理掉Eden和刚才用过的Survivor空间。
    • 如果Surviovr的空间不够,需要依赖其他内存(老年代)进行分配担保(虚拟机回检查老年代最大可用的连续空间是否大于新生代所有对象的总空间),这些对象直接通过分配担保机制进入老年代。(正常的需要Age达到15才可以进入老年代),如果担保失败,且不允许,则老年代需要进行一次Full GC。

3. 标记—整理算法(老年代)

垃圾收集器

IMG_20180627_194825_1.jpg

内存分配

  • 对象优先在Eden分配
  • 大对象直接进入老年代(大对象指很长的字符串以及数组)
  • 长期存活的对象进入老年代
    • 虚拟机给每个对象一个对象年龄(Age)计数器。对象每经过一次Minor GC Age就加一。(默认是15岁就会进入老年代)
    • 如果Survivor中相同年龄的所有对象的总和大于空间的一半,则年龄大于或等于该年龄的对象都可以直接进入老年代,无须等到要求的年龄。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,445评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,889评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,047评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,760评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,745评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,638评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,011评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,669评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,923评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,655评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,740评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,406评论 4 320
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,995评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,961评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,023评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,483评论 2 342

推荐阅读更多精彩内容