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)

            </div>
相关文章
|
3天前
|
存储 缓存 Java
java如何实现一个LRU(最近最少使用)缓存?
实现了一个LRU缓存,使用双向链表保持访问顺序,哈希表用于定位元素。Java代码中,`LRUCache`类包含容量、哈希表及链表头尾节点。`get`方法查哈希表,找到则移动至链表头并返回值,否则返回-1。`put`方法更新或插入节点,超出容量则移除最不常用节点。
16 6
|
10月前
|
Java C++
JVM学习日志(九) 对象的finalization机制
对象的finalization机制 简述
82 0
|
Java 程序员 Linux
Java多线程-线程的创建(Thread类的基本使用)
Java多线程-线程的创建(Thread类的基本使用)
119 0
Java多线程-线程的创建(Thread类的基本使用)
|
安全 Java API
《JUC并发编程 - 高级篇》03 - 共享对象之管程 下篇(Monitor | wait&notify | Park&Unpark | 线程状态转换 | 活跃性 | ReentrantLock)(一)
《JUC并发编程 - 高级篇》03 - 共享对象之管程 下篇(Monitor | wait&notify | Park&Unpark | 线程状态转换 | 活跃性 | ReentrantLock)
《JUC并发编程 - 高级篇》03 - 共享对象之管程 下篇(Monitor | wait&notify | Park&Unpark | 线程状态转换 | 活跃性 | ReentrantLock)(一)
《JUC并发编程 - 高级篇》03 - 共享对象之管程 下篇(Monitor | wait&notify | Park&Unpark | 线程状态转换 | 活跃性 | ReentrantLock)(四)
《JUC并发编程 - 高级篇》03 - 共享对象之管程 下篇(Monitor | wait&notify | Park&Unpark | 线程状态转换 | 活跃性 | ReentrantLock)
《JUC并发编程 - 高级篇》03 - 共享对象之管程 下篇(Monitor | wait&notify | Park&Unpark | 线程状态转换 | 活跃性 | ReentrantLock)(四)
《JUC并发编程 - 高级篇》03 - 共享对象之管程 下篇(Monitor | wait&notify | Park&Unpark | 线程状态转换 | 活跃性 | ReentrantLock)(二)
《JUC并发编程 - 高级篇》03 - 共享对象之管程 下篇(Monitor | wait&notify | Park&Unpark | 线程状态转换 | 活跃性 | ReentrantLock)
《JUC并发编程 - 高级篇》03 - 共享对象之管程 下篇(Monitor | wait&notify | Park&Unpark | 线程状态转换 | 活跃性 | ReentrantLock)(二)
|
Linux 调度
《JUC并发编程 - 高级篇》03 - 共享对象之管程 下篇(Monitor | wait&notify | Park&Unpark | 线程状态转换 | 活跃性 | ReentrantLock)(三)
《JUC并发编程 - 高级篇》03 - 共享对象之管程 下篇(Monitor | wait&notify | Park&Unpark | 线程状态转换 | 活跃性 | ReentrantLock)
《JUC并发编程 - 高级篇》03 - 共享对象之管程 下篇(Monitor | wait&notify | Park&Unpark | 线程状态转换 | 活跃性 | ReentrantLock)(三)
|
资源调度 Java 开发者
Thread 类实现多线程 | 学习笔记
快速学习 Thread 类实现多线程。
Thread 类实现多线程 | 学习笔记
|
SQL JavaScript Dubbo
PageHelper 使用 ThreadLocal 的线程复用问题,你用对了吗?
PageHelper 使用 ThreadLocal 的线程复用问题,你用对了吗?
PageHelper 使用 ThreadLocal 的线程复用问题,你用对了吗?