介绍:
Cleaner是JDk1.9之后提供的一个对象清理操作,主要的功能是进行finialize()方法的替代。
输入Java因为自身JVM的特性不用用户自己去回收垃圾,但是仍然存在此类操作。
public class Member {
public Member(){
System.out.println("诞生!");
}
@Override
protected void finalize() throws Throwable{//从JDk1.9开始不建议使用
System.out.println("回收:必死");
throw new Exception("不想死"); }
}
public class Main {
public static void main(String[] args) {
Member mm = new Member(); // 诞生
mm = null; // 成为垃圾
System.gc();
System.out.println("死亡并不结束!");
}
}
从JDk1.9开始不建议使用finialize()方法,从而建议使用AutoCloseable或者Cleaner进行处理。
新版本的清除操作:
public class Member implements Runnable{
public Member(){
System.out.println("【构造】Born");
}
@Override
public void run() { // 执行清除的时候,执行的是此操作
System.out.println("【回收】Death");
}
}
import java.lang.ref.Cleaner;
public class MemberCleaning implements AutoCloseable{ // 实现清除
private static final Cleaner cleaner = Cleaner.create(); // 创建清除处理
private Member member;
private Cleaner.Cleanable cleanable;
public MemberCleaning() {
this.member = new Member();
this.cleanable = this.cleaner.register(this,this.member); // 注册使用的对象
}
@Override
public void close() throws Exception {
this.cleanable.clean(); // 启动多线程
}
}
public class Main {
public static void main(String[] args) throws Exception{
try (MemberCleaning mc = new MemberCleaning()){
// 中间可以执行一些相关的代码
}catch (Exception e){
}
}
}
新一代的清除回收操作,考虑的是多线程的使用:
为了防止可能造成的多线程的延迟处理,许多对象回收前的处理都是单独通过一个线程完成的,这样能够保证执行性能的提高。