随笔都是学习笔记
随笔仅供参考,为避免笔记中可能出现的错误误导他人,请勿转载。

介绍:

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){

        }
    }
}

 

 新一代的清除回收操作,考虑的是多线程的使用:

  为了防止可能造成的多线程的延迟处理,许多对象回收前的处理都是单独通过一个线程完成的,这样能够保证执行性能的提高。

 

posted on 2022-02-03 14:42  时间完全不够用啊  阅读(1000)  评论(0编辑  收藏  举报