标签:指针 碰撞 老年 直接 vivo 情况 queue 填充 回收
线程私有 :程序计数器,JAVA虚拟机栈,本地方法栈
线程共享 :堆,方法区,运行时常量池,直接内存
指针碰撞
空闲列表
堆在某种程度上,也存在线程私有的部分哦
对象头 : Mark word,类型指针
实例数据
对齐填充 :任何对象的大小都必须是8字节的倍数
句柄访问
直接指针访问
内存泄露
内存溢出
jdk6中,常量池位于永久代(方法区)
jdk7中,常量池位于堆中
jdk8中,元空间取代了永久代
引用计数
可达性分析
虚拟机栈中的对象
类静态属性
方法区常量
本地方法引用的对象
虚拟机内部引用
被同步锁持有的对象
反映JVM内部情况的JMXBean,JVMTI 中注册的回调,本地代码缓存等 (?)
强引用
软引用
弱引用
虚引用
1.判断是否可达;
2.被标记,如果finalize()未被重写或者以及被执行过,直接进入第三步,否则,进入F-QUEUE,执行finalize()方法;
3.若仍然不可达,则回收
条件苛刻,详见P74
弱分代假说:决大多数对象都是朝生夕灭的
强分代假说:熬过越多次垃圾收集过程的对象就越难以消亡
夸代引用假说:跨代引用相对于同代引用仅占极少数
在新生代上,将老年代分为若干块,记录哪些块会存在跨代引用
一.部分收集(Partial GC)
1.新生代收集(Minor GC/Young GC)
2.老年代收集(Major GC/Old GC)
3.混合收集(Mixed GC)
二.整堆收集(Full GC) 包括方法区
标记-清除
标记-复制 (Eden,Survivor)
标记-整理
记录对象中属性哪些是引用
虽然暂时知道这是个什么东西,不过他为什么存在,我暂时无法理解.
同上
1.根节点枚举必须Stop The World
2.准确式内存:虚拟机可以知道内存中的某个数据是什么类型的
标签:指针 碰撞 老年 直接 vivo 情况 queue 填充 回收
原文地址:https://www.cnblogs.com/ZGQblogs/p/12578657.html