【Java_Spring】Day29 finalize()垃圾回收

2024-09-06 09:36

本文主要是介绍【Java_Spring】Day29 finalize()垃圾回收,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

finalize()方法

finalize() 是 Java 中 Object 类的一个方法,用于在对象被垃圾回收器回收之前进行清理操作。它是一种资源释放的回调机制,允许开发者在对象销毁前进行一些特定的清理工作,如关闭文件、释放系统资源等。

作用与原理:

  • 垃圾回收器回调:当垃圾回收器(Garbage Collector, GC)确定一个对象没有被任何引用时,它会在对象销毁之前调用该对象的 finalize() 方法。
  • 清理操作finalize() 方法可以用于释放一些非内存资源,例如关闭打开的文件、网络连接、数据库连接等。
  • 默认行为:如果你没有覆盖 finalize(),Java默认不会执行任何操作,因为 Object 类的 finalize() 是空实现的。

使用示例:

class MyClass {@Overrideprotected void finalize() throws Throwable {try {// 清理操作,如关闭文件或释放资源System.out.println("Finalize method called.");} finally {super.finalize();  // 调用父类的 finalize() 方法}}
}

finalize()的生命周期:

  1. 当对象不再被引用时,GC会将对象标记为可回收。
  2. GC在回收该对象之前,调用 finalize() 方法(如果该方法被重写)。
  3. 如果对象的 finalize() 方法没有显式释放资源,资源将继续被占用。
  4. 对象的 finalize() 方法仅会被调用一次,即使对象被再次引用,方法也不会再被调用。

问题与局限:

  • 不确定性finalize() 方法的执行时间和调用时机是不确定的,取决于垃圾回收器的运行,可能会导致资源长期未被释放。
  • 性能问题:依赖 finalize() 可能会降低垃圾回收器的性能,因为它增加了对象的生命周期。
  • 替代方案:Java 9 已弃用 finalize(),推荐使用 try-with-resources 或实现 AutoCloseable 接口来进行资源管理。

finalize()的替代方案:

  • try-with-resources:从Java 7开始,推荐使用 try-with-resources 语法来自动关闭资源,例如文件或数据库连接。需要类实现 AutoCloseable 接口。
try (MyResource resource = new MyResource()) {// 使用资源
}  // 资源在这里自动关闭
  • CleanerPhantomReference:在更复杂的场景中,可以使用 java.lang.ref.CleanerPhantomReference 来替代 finalize() 实现资源管理。

总结:

  • finalize() 方法用于在对象被GC回收前进行清理操作,但由于其不确定性和效率问题,它不适合在现代Java开发中使用。
  • 推荐使用 try-with-resources 或实现 AutoCloseable 接口来代替 finalize(),以确保资源可以被及时、可靠地释放。

这篇关于【Java_Spring】Day29 finalize()垃圾回收的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1141660

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

离心萃取机废旧磷酸铁锂电池回收工艺流程

在废旧磷酸铁锂电池的回收工艺流程中,离心萃取机主要应用于萃取除杂的步骤,以提高回收过程中有价金属(如锂)的纯度。以下是结合离心萃取机应用的废旧磷酸铁锂电池回收工艺流程: 电池拆解与预处理 拆解:将废旧磷酸铁锂电池进行拆解,分离出电池壳、正负极片、隔膜等部分。破碎与筛分:将正负极片进行破碎处理,并通过筛分将不同粒径的物料分开,以便后续处理。 浸出与溶解 浸出:采用适当的浸出工艺(如二段式逆

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听