Cleaner 类|学习笔记

简介: 快速学习 Cleaner 类

开发者学堂课程【 Java 高级编程Cleaner 类】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址https://developer.aliyun.com/learning/course/20/detail/321


Cleaner 类


目录:

一、Cleaner 简介

二、范例:观察传统回收


一、Cleaner 简介


Cleaner 是在 JDK 1.9 之后提供的一个对象清理操作,其主要的功能是进行 finialize() 方法的替代。

在 C++ 语言里面有两种特殊的函数:构造函数、析构函数(对象手工回收),在 Java里面所有的垃圾空间都是通过 GC 自动回收的,所以很多情况下是不需要使用这类析构函数的,也正是因为如此,所以 Java 并没有提供这方面支持。.

但是 Java 本身依然提供了给用户收尾的操作,每一个实例化对象在回收之前至少给它一个喘息的机会,最初实现对象收尾处理的方法是 Object 类中所提供的 finalize (方法,这个方法的定义如下:

@ Deprecated( since="9")

protected void finalize( ) throws Throwable.

该替换指的是不建议继续使用这个方法了,而是说子类可以继续使用这个方法名称。

但是这个方法上最大的特点是抛出了一个 Throwable 异常类型,而这个异常类型分为两个子类型:Error、Exception,平常所处的都是 Exception。

 

二、范例:观察传统回收

package cn.mldn.demo;

class Member t

public Member()

System.out.print1n(”【构造】在一个雷电交加的日子里面,林强诞生了。”);

@Override

protected void finalize() throws Throwable

System.out.println(”【回收】最终你一定要死的。”);

throw new Exception(”我还要再活 500 年...”);

public class JavaAPIDemo [

public static void main(String[] args) throws Exception

Member mem = new Member();// 诞生

mem = null ;// 成为垃圾

System.gc();

System.out.println(”太阳照常升起,地球照样转动。”);


但是从 JDK 1.9  开始,这操作已经不建议使用了,而对于对象回收释放。从 JDK1.9 开始建议开发者使用 AutoCloseable 或者使用 java.lang .ref.Cleaner 类进行回收处理( Cleaner 也支持有 AutoCloseable 处理)。

package cn.mldn.demo;

class Member implements Runnable (

public Member()t

System.out.print1n(”【构造】在一个雷电交加的日子里面,林强诞生了。”);

@Override

public void run()£//执行清除的时候执行的是此操作

System.out.println("【回收】最终你一定要死的。”);

classMemberCleaning 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 JavaAPIDemo

public static void main(String[] args) throws Exceptionf

try(MemberCleaning mc二new MemberCleaning())t

// 中间可以执行一些相关的代码

catch(Exception e)

相关文章
|
7月前
muduo源码剖析之Buffer缓冲区类
Buffer封装了一个可变长的buffer,支持廉价的前插操作,以及内部挪腾操作避免额外申请空间使用vector作为缓冲区(可自动调整扩容)
79 0
muduo源码剖析之Buffer缓冲区类
|
6月前
|
安全 Java 数据安全/隐私保护
深入理解java中Unsafe类及其实现原理
深入理解java中Unsafe类及其实现原理
132 0
|
7月前
|
存储 安全
除了Lock对象,还有其他方法可以实现多线程安全的单例模式吗?
【2月更文挑战第5天】【2月更文挑战第12篇】除了Lock对象,还有其他方法可以实现多线程安全的单例模式吗?
37 1
|
Java C++
JVM学习日志(九) 对象的finalization机制
对象的finalization机制 简述
101 0
|
缓存 前端开发 Java
【Netty官方文档翻译】引用计数对象(reference counted objects)
【Netty官方文档翻译】引用计数对象(reference counted objects)
89 0
|
Oracle 前端开发 算法
JDK源码(21)-Unsafe
JDK源码(21)-Unsafe
183 0
JDK源码(21)-Unsafe
|
SQL JavaScript Dubbo
PageHelper 使用 ThreadLocal 的线程复用问题,你用对了吗?
PageHelper 使用 ThreadLocal 的线程复用问题,你用对了吗?
PageHelper 使用 ThreadLocal 的线程复用问题,你用对了吗?
|
资源调度 Java 开发者
Thread 类实现多线程 | 学习笔记
快速学习 Thread 类实现多线程。
Thread 类实现多线程 | 学习笔记
|
Java 开发者 C++
Cleaner 类|学习笔记
快速学习 Cleaner 类
168 0
|
设计模式 存储 缓存
快速带你看完《Effective Java》—— 创建和销毁对象篇
1 静态工厂代替构造器 2 构造函数有多个参数时要考虑使用构建器 3 使用private构造器或枚举类型强化Singleton属性 4 使用privete的构造函数强化不可实例化的能力 5 引用资源时应优先考虑依赖注入 6 避免创建不必要的对象 7 消除过期的对象引用 8 避免使用终结方法和清除方法 9 try-with-resources优先于try-finally
快速带你看完《Effective Java》—— 创建和销毁对象篇