【003】【Java虚拟机——对象死亡的判断】
对象死亡!
垃圾收集器在对堆进行回收前,首先要做的事情就是要确定这些对象之中哪些还“存活”着, 哪些已经“死去" (即不可能再被不论什么途径使用的对象)。
1) 引用计数算法
给每一个对象中加入一个引用计数器,每当有一个地方引用它时, 计数器值就加l ; 当引用失效时,计数器值就减l :不论什么时刻计数器为0 的对象就是不可能再被使用的。引用计数算法( Reference Counting )的实现简单,判定效率也非常高,在大部分情况下它都是一个不错的算法。
Java 虚拟机里面没有选用引用计数算法来管理内存。当中最基本的原因是它非常难解决对象之间相互循环引用的问题。
2) 可达性分析算法
就是通过一系列的称为“GC Roots”的对象作为起始点,从这些节点開始向下搜索。搜索所走过的路径称为引用链(Reference Chain) ,当一个对象到GC Roots 没有不论什么引用链相连(用图克的话来说,就是从GC Roots 到这个对象不可达〕时,则证明此对象是不可用。
可作为GC Roots 的对象包含以下几类:
虚拟机钱(栈帧中的本地变量表)中引用的对象。
方法区中类静态属性引用的象。
方法区中常量引用的对象。.
本地方法战中JNI (native方法)引用的判象。
3) 再谈引用
在JDK 1.2之后。 Java对引用的概念进行了扩充将引用分为强引用( Strong Reference )、软引用( Soft Reference)、弱引用( Weak Reference )引、虚引用( Phantom Reference),它们的引用强度依次逐渐减弱。
强引用就是指在程序代码之中普遍在在的。类似Object obj = new Object(),仅仅要强引用还存在,垃圾收集器永远不会回收据被引用的对象。
软引用是用来描写叙述一些还实用但并没必要的对象。
对于软引用所联着的对象。在系统将要发生内存溢出异常之前。将会把这些对象列进垃圾回收范围之中进行第二次回收。
假设这次回收还是没有足够的内存,才会抛出内存谧出异常。在JDK1.2 之后。提供了Soft
Reference 类来实现软引用。弱引用也是用来描写叙述非必需对象的。被弱引用关联的对象仅仅能生存到下一次垃墩收集发生之前。当垃圾收集器工作肘。不管当前内存是否足够,都会回收掉仅仅被弱引用关联的对象。在JDK
1.2 之后,提供了WeakReference 类来实现弱引用。虚引用也称为幽灵引用或者幻影引用,它是最弱的一种引用关系。一个对象是否有虚引用的存在。全然不会对其生存时间构成影响,也无也通过虚引用来取得一个对象实例。为一个对象设置虚引用关联的唯一目的就是希望能在这个对象被收集器回收时收到一个系统通知。在JDK
1.2 之后,提供了PhantomReference 类来实现虚引用。
4) 生存还是死亡
即使在可达性分析算法中不可边的对象。也并不是是“非死不可”的。,要真正宣告一个对象死亡,至少要经胁两次标记过程:假设对象在进行可达性分析后发现没有与GC Roots 相连接的引用链。那它将会被第一次标记而且进行一次筛选,筛选的条件是此对象是否有必要运行finalize() 方法。
当对象没有覆盖fnalize()方法,或者finalize()方法已经被虚拟机调用过。虚拟机将这两种情况都视为“没有必、要运行”。
假设这个对象被判定为有必要运行finalize()方法,那么这个对象将会被放置在一个名为F-Queue 的队列之中,井在稍后由一条由虚拟机自己主动建立的、低优先级的Finalizer线程去运行。
“运行”是指虚拟机会触发这种方法,但并不承诺会等待它运行结束。
finalize()方越是对象逃脱死亡命运的最后一次机会,稍后GC 将对F-Queue 中的对象进行第二次小规模的标记。假设对象这时候还没有逃脱。就能够回收了。
5) 方法回收区
方法区( HotSpot 虚拟机永久代 )垃圾收集主要回收两部分内容:废弃常量和没用的类。类须要同一时候满足以下3 个条件才干算是“没用的类”:
该类全部的实例都已经被回收,也就是Java 堆中不存在该类的不论什么实例。
载入该类的ClassLoader 已经被回收。
该类相应的java.lang.Class 对象没有在不论什么地方被引用,无法在不论什么地方通过反射訪问该类的方法
虚拟机能够对满足上述3 个条件的无用类进行回收,但并不一定进行回收。
【參见】【深经了解Java虚拟机(再版)】【周之螟】
版权声明:本文博主原创文章。博客,未经同意不得转载。
【003】【Java虚拟机——对象死亡的判断】的更多相关文章
- Java虚拟机-对象的创建和访问
一.对象的创建: 创建对象在java上面是很简单的,使用new关键字就可以了,但是其实在虚拟机中,java对象的创建是一个复杂的过程. 当java虚拟机遇到一个new的指令的时候,对象创建的程序正式启 ...
- 深入理解java虚拟机---对象的访问定位(十)
引用其他人的文章: https://www.cnblogs.com/YYfish/p/6722258.html 那是怎么访问对象呢? java 程序是通过栈上的reference数据来操作堆上的具体对 ...
- 深入理解java虚拟机---对象的结构(九)
注意: 我们可以看到的就是InstanceData的数据. 先转载一篇文章作为开头,因为讲的非常详细,我就简单加工下放到这里: 对象结构 在HotSpot虚拟机中,对象在内存中存储的布局可以分为3块区 ...
- Java虚拟机对象存活标记及垃圾收集算法解析
一.对象存活标记 1. 引用计数算法 给对象中添加一个引用计数器,每当有一个地方引用它时,计数器就加1:当引用失效时,计数器就减1:任何时刻计数器都为0的对象就是不可能再被使用的. 引用计数算法(Re ...
- 深入理解java虚拟机---对象的创建过程(八)
1.对象的创建过程 由于类的加载是一个很复杂的过程,所以这里暂时略过,后面会详细讲解,默认为是已加载过的类.着重强调对象的创建过程. 注意: 最后一步的init方法是代码块和构造方法. 以上是总图,下 ...
- Java虚拟机系列(二)---HotSpot虚拟机对象
都知道Java是一门面向对象的编程语言,在Java程序运行过程中,无时无刻不在创建对象,所以这节来总结一下HotSpot虚拟机中的Java对象. 一.Java虚拟机对象的创建过程. 在语义层面创建一个 ...
- 深入理解java虚拟机(三)对象回收判断算法以及死亡过程
在堆里面存放着Java几乎所有的对象实例,垃圾收集器要进行垃圾回收,要做的第一步便是找出那些对象是需要回收的. 怎么判断对象是否需要回收? 常用的方法有两种. 1.引用计数算法.为每一个对象添加一个引 ...
- 深入Java虚拟机--判断对象存活状态
程序计数器,虚拟机栈和本地方法栈 首先我们先来看下垃圾回收中不会管理到的内存区域,在Java虚拟机的运行时数据区我们可以看到,程序计数器,虚拟机栈,本地方法栈这三个地方是比较特别的.这个三个部分的特点 ...
- 判断Java对象死亡的两种常用算法
当对象不馁引用的时候,这个对象就是死亡的,等待GC进行回收. 1.引用计数法 概念: 给对象中添加一个引用计数器,每当有一个地方引用它时,计数器值就增加1:当应用失效时,计数器值就减1:任何时刻计数器 ...
随机推荐
- 25、驱动调试之打印到proc虚拟文件
1.dmesg指令是通过读/proc/kmsg来获取打印信息,也可以通过cat /proc/kmsg打印: 说明:kmsg是环形缓存区,只能读一次 2.内核中fs/proc目录下有相关文件,比如pro ...
- thinkphp3.2使用join联合查询
$members=$model->table('zhope_card A') ->join('zhope_user U ON A.adduser=U.id',"LEFT" ...
- 【29.42%】【POJ 1182】食物链
Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 64875 Accepted: 19085 Description 动物王国中有三 ...
- 并发队列ConcurrentLinkedQueue 和 阻塞队列LinkedBlockingQueue用法
在Java多线程应用中,队列的使用率很高,多数生产消费模型的首选数据结构就是队列(先进先出).Java提供的线程安全的Queue可以分为阻塞队列和非阻塞队列,其中阻塞队列的典型例子是BlockingQ ...
- java中关于File类的mkdirs()和FIle()构造方法在windows环境内网测试总结
环境:环境是内网windows,传入路径的时候不带盘符,并且服务器的win10也不是超级管理员账户 关于File类的mkdirs()远程访问创建不了文件和路径的问题. 如果浏览器操作者是windows ...
- java File类的基本使用
package com.soar.file; import java.io.File; import java.io.IOException; public class Demo2_FileMetho ...
- [Grid Layout] Describe a grid layout using named grid lines
We can use named grid lines to describe our grid layout. Let’s see how to apply this to our grid-tem ...
- 【poj3468】A Simple Problem with Integers
Time Limit: 5000MS Memory Limit: 131072K Total Submissions: 97008 Accepted: 30285 Case Time Limi ...
- ArcEngine中最短路径的实现
原文 ArcEngine中最短路径的实现 最短路径分析属于ArcGIS的网络分析范畴.而ArcGIS的网络分析分为两类,分别是基于几何网络和网络数据集的网络分析.它们都可以实现最短路径功能.下面先介绍 ...
- Go 快速入门
入门 Go 语言需要多久?答案是 -- 读完这篇文章的时间!不妨找一个周末的下午,踏上 Go 之旅吧! 更新记录: 2016.12.12: 完成重制 2016.11.02: 增加重点理解和参考链接 2 ...