destroy方法与钩子函数

本文深入解析Spring框架中Bean的销毁过程,包括JVM关闭时触发的钩子函数、注册及销毁逻辑,以及bean销毁的顺序与条件。了解如何通过实现特定接口或自定义方法来控制bean的生命周期。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

结论

  JVM关闭时,会触发钩子函数,Spring会在注册的钩子函数中回调bean的destroy方法销毁bean;

注册过程

 注册时机:Spring容器启动时,run() --> refreshContext(),如下图所示
在这里插入图片描述

注册逻辑如下,AbstractApplicationContext.registerShutdownHook()

public void registerShutdownHook() {
		if (this.shutdownHook == null) {
			// No shutdown hook registered yet.
			this.shutdownHook = new Thread() {
				@Override
				public void run() {
					synchronized (startupShutdownMonitor) {
						doClose();
					}
				}
			};
			Runtime.getRuntime().addShutdownHook(this.shutdownHook);
		}
	}

Spring关闭过程

  1. 发布ContextClosedEvent事件;
  2. 销毁容器中所有的bean;
  3. 关闭容器本身;

bean的销毁过程

  1. 首先,从disposableBeans获取所有待销毁的bean,然后倒序依次销毁(与创建顺序相反);
    在这里插入图片描述
  2. 先销毁依赖当前bean的其它bean,再销毁当前bean;
    在这里插入图片描述

注册到disposableBeans的几种情况

  1. 实现了DisposableBean接口;
  2. 在xml配置文件中自定义了destroy方法;
  3. 实现了AutoCloseable接口;

参考:

  1. https://my.oschina.net/evermaze/blog/1594330;
### Vue.js 生命周期钩子函数详解 #### 创建期间的生命周期钩子 `beforeCreate` 钩子在实例初始化之后,数据观测 (data observer) 和 event/watcher 事件配置之前被调用。此时 `data` 和 `methods` 尚未初始化[^1]。 ```javascript new Vue({ beforeCreate() { console.log('beforeCreate:', this.$el, this.$data); // 输出 null undefined } }); ``` `created` 钩子在实例完成数据观测、属性和方法初始化后立即调用。此时可以访问到完整的 `this` 上下文以及响应式的数据[^2]。 ```javascript new Vue({ data() { return { message: 'Hello' }; }, created() { console.log('created:', this.message); // 输出 Hello } }); ``` #### 挂载期间的生命周期钩子 `beforeMount` 钩子发生在挂载开始之前,相关的 render 函数首次被调用前。此时模板编译尚未开始,虚拟 DOM 还没生成[^3]。 ```javascript new Vue({ template: `<div>{{message}}</div>`, data() { return { message: 'World' }; }, beforeMount() { console.log('beforeMount:', this.$el.innerHTML); // 输出 "" } }); ``` `mounted` 钩子会在挂载完成后被调用,此时 el 被新创建的 vm.$el 替换,并挂载到了实例上。通常用于发送网络请求获取初始数据或操作真实DOM节点[^4]。 ```javascript new Vue({ mounted() { console.log('mounted:', this.$el.outerHTML); // 可能输出类似于 <div id="app">World</div> } }); ``` #### 更新期间的生命周期钩子 当组件状态更新时会触发相应的生命周期钩子: - `beforeUpdate`: 数据更新时,在重新渲染之前调用此钩子。 - `updated`: 组件重绘完毕后调用该钩子,注意避免在此处修改引起再次更新的状态以防陷入死循环。 #### 销毁期间的生命周期钩子 最后两个重要的生命周期钩子涉及组件销毁过程: - `beforeDestroy`: 实例销毁之前调用。在这一步,实例仍然完全可用。 - `destroyed`: 当Vue实例被销毁后调用。清理工作如解绑监听器、停止计时器等应该放在这里处理。 ```javascript new Vue({ methods: { destroyComponent() { this.$destroy(); } }, destroyed() { console.log('The component has been destroyed.'); } }); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值