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){ } } }
新一代的清除回收操作,考虑的是多线程的使用:
为了防止可能造成的多线程的延迟处理,许多对象回收前的处理都是单独通过一个线程完成的,这样能够保证执行性能的提高。