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)

相关文章
|
6月前
|
存储 安全 算法
深入剖析JVM内存管理与对象创建原理
JVM内存管理,JVM运行时区域,直接内存,对象创建原理。
104 2
|
5月前
|
安全 Java 程序员
在Java中,finalization是一种机制,允许对象在被垃圾收集器回收之前执行一些清理操作。
【6月更文挑战第24天】Java中的finalization机制允许对象在被垃圾收集前执行清理,以释放系统资源或处理敏感信息。`finalize()`方法用于定义此类操作,但它不是可靠的资源管理策略,因为调用时机不确定且可能影响性能。尽管可用于清理外部资源或作为保护措施,但应避免依赖finalization,而应优先采用手动资源管理,遵循“创建者负责”原则。
30 1
|
Java C++
JVM学习日志(九) 对象的finalization机制
对象的finalization机制 简述
98 0
|
存储 缓存 Java
【JVM】8. 对象实例化及直接内存(2)
8.2.3. 对齐填充(Padding) 不是必须的,也没有特别的含义,仅仅起到占位符的作用 举例
|
缓存 监控 算法
细说jvm(三)、对象创建的内存分配
细说jvm(三)、对象创建的内存分配
11785 3
|
安全 Java 调度
多线程(三):Thread 类的基本属性
多线程(三):Thread 类的基本属性
117 0
多线程(三):Thread 类的基本属性
|
存储 缓存 算法
jvm之对象实例化及直接内存解读
jvm之对象实例化及直接内存解读
|
存储 算法 Java
【JVM】8. 对象实例化及直接内存(1)
8.1. 对象实例化 8.1.1. 创建对象的方式 new:最常见的方式、Xxx的静态方法,XxxBuilder/XxxFactory的静态方法 Class的newInstance方法:反射的方式,只能调用空参的构造器,权限必须是public Constructor的newInstance(XXX):反射的方式,可以调用空参、带参的构造器,权限没有要求 使用clone():不调用任何的构造器,要求当前的类需要实现Cloneable接口,实现clone() 使用序列化:从文件中、从网络中获取一个对象的二进制流
|
存储 缓存 算法
<JVM上篇:内存与垃圾回收篇>08-对象实例化及直接内存
<JVM上篇:内存与垃圾回收篇>08-对象实例化及直接内存
<JVM上篇:内存与垃圾回收篇>08-对象实例化及直接内存
|
SQL JavaScript Dubbo
PageHelper 使用 ThreadLocal 的线程复用问题,你用对了吗?
PageHelper 使用 ThreadLocal 的线程复用问题,你用对了吗?
PageHelper 使用 ThreadLocal 的线程复用问题,你用对了吗?