Spring底层原理学习笔记--第六讲--(Aware与InitializingBean接口及@Autowired失效分析)

Aware接口

  • 1.Aware接口提供了一种【内置】的注入手段,可以注入BeanFactory,ApplicationContext
  • 2.InitiazingBean接口提供了一种【内置】的初始化手段
  • 3.内置的注入和初始化不收扩展功能的影响,总会被执行,因此Spring框架内部的类常用它们
  • 4.实战:@Autowired失效分析

Aware与InitializingBean接口

A06Application.java

package com.lucifer.itheima.a06;import org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor;
import org.springframework.context.annotation.CommonAnnotationBeanPostProcessor;
import org.springframework.context.support.GenericApplicationContext;/*** Aware接口及InitializingBean接口*/
public class A06Application {public static void main(String[] args) {/*1.Aware接口用于注入一些与容器相关信息,例如a.BeanNameAware 注入bean的名字b.BeanFactoryAware 注入BeanFactory容器c.ApplicationContextAware注入ApplicationContext容器d.EmbeddedValueResolverAware ${}*/// 输出结果为
//        15:56:19.704 [main] INFO com.lucifer.itheima.a06.MyBean - 当前bean com.lucifer.itheima.a06.MyBean@5bcab519 名字叫:myBean
//        15:56:19.706 [main] INFO com.lucifer.itheima.a06.MyBean - 当前bean com.lucifer.itheima.a06.MyBean@5bcab519 容器是:org.springframework.context.support.GenericApplicationContext@5aaa6d82, started on Wed Nov 08 15:56:19 CST 2023
//        15:56:19.706 [main] INFO com.lucifer.itheima.a06.MyBean - 当前bean com.lucifer.itheima.a06.MyBean@5bcab519初始化GenericApplicationContext context = new GenericApplicationContext();context.registerBean("myBean",MyBean.class);//不加这两句
//        context.registerBean(AutowiredAnnotationBeanPostProcessor.class);
//        context.registerBean(CommonAnnotationBeanPostProcessor.class);//的输出结果是
//        16:26:47.976 [main] INFO com.lucifer.itheima.a06.MyBean - 当前bean com.lucifer.itheima.a06.MyBean@5bcab519 名字叫:myBean
//        16:26:47.979 [main] INFO com.lucifer.itheima.a06.MyBean - 当前bean com.lucifer.itheima.a06.MyBean@5bcab519 容器是:org.springframework.context.support.GenericApplicationContext@5aaa6d82, started on Wed Nov 08 16:26:47 CST 2023
//        16:26:47.979 [main] INFO com.lucifer.itheima.a06.MyBean - 当前bean com.lucifer.itheima.a06.MyBean@5bcab519初始化// 加上那两句(后处理器)的输出结果是
//        16:28:24.501 [main] INFO com.lucifer.itheima.a06.MyBean - 当前bean com.lucifer.itheima.a06.MyBean@262b2c86 使用!Autowired 容器是:org.springframework.context.support.GenericApplicationContext@5aaa6d82, started on Wed Nov 08 16:28:24 CST 2023
//        16:28:24.501 [main] INFO com.lucifer.itheima.a06.MyBean - 当前bean com.lucifer.itheima.a06.MyBean@262b2c86 名字叫:myBean
//        16:28:24.501 [main] INFO com.lucifer.itheima.a06.MyBean - 当前bean com.lucifer.itheima.a06.MyBean@262b2c86 容器是:org.springframework.context.support.GenericApplicationContext@5aaa6d82, started on Wed Nov 08 16:28:24 CST 2023
//        16:28:24.501 [main] INFO com.lucifer.itheima.a06.MyBean - 当前bean com.lucifer.itheima.a06.MyBean@262b2c86 使用@PostConstruct 初始化
//        16:28:24.501 [main] INFO com.lucifer.itheima.a06.MyBean - 当前bean com.lucifer.itheima.a06.MyBean@262b2c86初始化context.registerBean(AutowiredAnnotationBeanPostProcessor.class);context.registerBean(CommonAnnotationBeanPostProcessor.class);context.refresh();context.close();/*** 2.b、c、d的功能用!Autowired就能实现,为什么还要用Aware接口* 简单地说:*      a.@Autowired的解析需要用到bean后处理器,属于扩展功能*      b.而Aware接口属于内置功能,不加任何扩展,Spring就能识别* 某些情况下,扩展功能会实现,而内置功能不会生效** 问1:你会发现用Aware注入ApplicationContext成功,而@Autowired注入ApplicaitonContext失效*/}
}

MyBean.java

package com.lucifer.itheima.a06;import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.BeansException;
import org.springframework.beans.factory.BeanNameAware;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;import javax.annotation.PostConstruct;@Slf4j
public class MyBean implements BeanNameAware, ApplicationContextAware, InitializingBean {@Overridepublic void setBeanName(String name) {log.info("当前bean "+ this + " 名字叫:" + name);}@Overridepublic void setApplicationContext(ApplicationContext applicationContext) throws BeansException {log.info("当前bean " + this + " 容器是:" + applicationContext);}@Overridepublic void afterPropertiesSet() throws Exception {log.info("当前bean " + this + "初始化");}@Autowiredpublic void aaa(ApplicationContext applicationContext) {log.info("当前bean " + this + " 使用!Autowired 容器是:" + applicationContext);}@PostConstructpublic void init() {log.info("当前bean " + this + " 使用@PostConstruct 初始化");}
}

@Autowired失效分析

A06Application.java

package com.lucifer.itheima.a06;import org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor;
import org.springframework.context.annotation.CommonAnnotationBeanPostProcessor;
import org.springframework.context.annotation.ConfigurationClassPostProcessor;
import org.springframework.context.support.GenericApplicationContext;/*** Aware接口及InitializingBean接口*/
public class A06Application {public static void main(String[] args) {/*1.Aware接口用于注入一些与容器相关信息,例如a.BeanNameAware 注入bean的名字b.BeanFactoryAware 注入BeanFactory容器c.ApplicationContextAware注入ApplicationContext容器d.EmbeddedValueResolverAware ${}*/GenericApplicationContext context = new GenericApplicationContext();
//        context.registerBean("myBean",MyBean.class);
//        context.registerBean("myConfig1",MyConfig1.class);context.registerBean("myConfig2",MyConfig2.class);context.registerBean(AutowiredAnnotationBeanPostProcessor.class);  //能解析@Autowired注解context.registerBean(CommonAnnotationBeanPostProcessor.class);     //能解析@PostConstruct注解context.registerBean(ConfigurationClassPostProcessor.class);  //能解析@ComponentScan @Bean @Import @ImportResourcecontext.refresh();   //1.会到容器中找到所有beanFactory后处理器来执行 2.添加bean后处理器  3.初始化单例context.close();/*** 2.b、c、d的功能用!Autowired就能实现,为什么还要用Aware接口* 简单地说:*      a.@Autowired的解析需要用到bean后处理器,属于扩展功能*      b.而Aware接口属于内置功能,不加任何扩展,Spring就能识别* 某些情况下,扩展功能会实现,而内置功能不会生效** 问1:你会发现用Aware注入ApplicationContext成功,而@Autowired注入ApplicaitonContext失效*//***学到了什么*     a.Aware接口提供了一种[内置]的注入手段,可以注入BeanFactory,ApplicationContext*     b.InitializingBean接口提供了一种【内置】的初始化手段*     c.内置的注入和初始化不受扩展功能的影响,总会被执行,因此Spring框架内的类常用它们*/}
}

MyConfig1.java

package com.lucifer.itheima.a06;import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.config.BeanFactoryPostProcessor;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;import javax.annotation.PostConstruct;@Configuration
@Slf4j
public class MyConfig1 {@Autowiredpublic void setApplicationContext(ApplicationContext applicationContext) {log.info("注入 ApplicationContext");}@PostConstructpublic void init() {log.info("初始化");}@Bean // beanFactory后处理器public BeanFactoryPostProcessor processor1() {return beanFactory -> {log.info("执行 processor1");};}}

MyConfig2.java

package com.lucifer.itheima.a06;import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.BeansException;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.beans.factory.config.BeanFactoryPostProcessor;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;@Configuration
@Slf4j
public class MyConfig2 implements InitializingBean, ApplicationContextAware {@Overridepublic void afterPropertiesSet() throws Exception {log.info("初始化");}@Overridepublic void setApplicationContext(ApplicationContext applicationContext) throws BeansException {log.info("注入 ApplicationContext");}@Bean // beanFactory后处理器public BeanFactoryPostProcessor processor1() {return beanFactory -> {log.info("执行 processor1");};}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/137616.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

页表和cache

页表基本原理 页表主要用来将虚拟地址映射到物理地址,在使用虚拟地址访问内存时,微处理器首先将虚拟地址拆分成页号和页内偏移量,然后使用页号在页表中查找对应的物理页框号,将物理页地址加上页内偏移量,得到最终的物…

IDEA高效编程快捷键

IDEA高效编程快捷键 for循环快捷键 快速生成for循环 foriTABfor (int i 0; i < ; i) {}在for循环中使用索引 iterTABfor (String s : list) {}在for循环中进行if条件判断 ifnTABif (list null) {} soutTAB快捷键 System.out.println();psfEnter快捷键 p…

arcgis 网络分析 生成可达范围/等时线

需求&#xff1a;生成从地铁站步行10分钟可达的范围面图层。 线图层预处理 在精度要求不是很高的情况下&#xff0c;可采用OSM路网&#xff0c;从中剔除不允许步行的道路类型&#xff1a;高速公路、快速路。 在路网图层中新增一个字段“步行时间”&#xff0c;用字段计算器&…

C++之map的介绍

C之map的介绍 1。定义和初始化 map可以使用一对<key, value>来初始化&#xff0c;如下所示&#xff1a; std::map<int, std::string> my_map { {1, "one"}, {2, "two"}, {3, "three"} };这将创建一个map&#xff0c;其中键是整数&…

Three.js 实现简单的PCD加载器(可从本地读取pcd文件)【附完整代码】

1 功能实现 初始会显示我们之前 SfM 做出的点云&#xff0c;包括相机位置可以点击右上角加载你本地的PCD文件可以通过选择多个文件加载多个点云并显示在同一场景中可以通过左上角的控制界面查看/调整点云的属性&#xff0c;如点大小、颜色等可以通过右上角的控制界面选择旋转 …

【考研数据结构代码题3】用栈实现十进制数转为八进制数

题目&#xff1a;将十进制数m1348转换成八进制数 难度&#xff1a;★ 算法思路&#xff1a;十进制转八进制的核心原理是“用辗转相除法不断对8取余&#xff0c;最后将余数反向输出”&#xff0c;即先求出来的余数后输出&#xff0c;符合“先进后出”的栈的特性&#xff0c;故设…

AI:71-基于深度学习的植物叶片识别

🚀 本文选自专栏:AI领域专栏 从基础到实践,深入了解算法、案例和最新趋势。无论你是初学者还是经验丰富的数据科学家,通过案例和项目实践,掌握核心概念和实用技能。每篇案例都包含代码实例,详细讲解供大家学习。 📌📌📌在这个漫长的过程,中途遇到了不少问题,但是…

dRep-基因组质控、去冗余及物种界定

文章目录 Install依赖关系 常用命令常见问题pplacer线程超过30报错当比较基因组很多&#xff08;>4096&#xff09;有了Bdv.csv文件后无需输入基因组list 超多基因组为什么需要界定种&#xff1f;dRep重要概念次级ANI的选择Minimum alignment coverage3. 选择有代表性的基因…

linux 操作系统

先讲一下叭&#xff0c;自己学这的原因&#xff0c;是因为我在做项目的时候使用到啦Redis&#xff0c;其实在windows系统上我其实也装啦Redis上&#xff0c;但是我觉得后期在做其他的项目的时候可能也会用到这个然后就想着要不先学学redis&#xff0c;然后在后面也不至于什么都…

解决 matplotlib 中文字体无法显示问题

问题表现 使用 matplotlib 呈现出图片中文为方框□&#xff0c;表现如下所示 查找了以下解法&#xff1a; from matplotlib.font_manager import FontProperties # 指定字体路径 font_properties FontProperties(fname"./SimHei.ttf") plt.rcParams[font.family]…

【Docker安装RockeMQ:基于Windows宿主机,并重点解决docker rocketMQ安装情况下控制台无法访问的问题】

拉取镜像 docker pull rocketmqinc/rocketmq创建网络 docker network create rocketmq-net构建namesrv容器 docker run -d -p 9876:9876 -v D:/dockerFile/rocketmq/namesrv/logs:/root/logs -v D:/dockerFile/rocketmq/namesrv/store:/root/store --network rocketmq-net -…

图论——Dijkstra算法matlab代码

Dijkstra算法步骤 (1)构造邻接矩阵 (2)定义起始点 (3)运行代码 M=[ 0 5 9 Inf Inf Inf InfInf 0 Inf Inf 12 Inf InfInf 3 0 15 Inf 23 InfInf 6 Inf 0 Inf 8 7Inf 12 Inf 5 0 I…

lightdb Oracle模式下to_char支持格式‘HH24MiSS‘

文章目录 背景示例其他 背景 TO_CHAR(日期类型, 格式串) 函数根据格式串要求将日期类型的数据转为字符串&#xff0c; 以格式串HH24MISS举例&#xff0c;在Oracle中Hh24MiSS hh24miss结果都是一致的。 如下示例&#xff1a; SQL> select to_char(sysdate, HH24MISS) c1 …

计算机网络学习笔记(五):运输层(待更新)

目录 5.1 概述 5.1.1 TCP协议的应用场景 5.1.2 UDP协议的应用场景 5.2 三大关系 5.2.1 传输层协议和应用层协议之间的关系 5.3 用户数据报协议UDP(User Datagram Protocol) 5.3.1 UDP的特点 5.3.2 UDP的首部 5.4 传输控制协议TCP(Transmission Control Protocol) 5.…

obs whip 100ms端到端时延 webrtc验证

obs----whip---->媒体服务-----whep-----→chrome播放器&#xff08;webrtc demo&#xff09; 所有软件在同一台机器 1&#xff09;h264251080p 平均时延&#xff1a;162.8ms 采样点ms&#xff1a;167151168169151168166168167153 2&#xff09;h264301080p 平均时延&…

torch.mm

torch.mm(input, mat2, *, outNone) → Tensor执行矩阵input和mat2的矩阵乘法运算。 如果input是&#xff08;nm&#xff09;张量&#xff0c;mat2是&#xff08;mp&#xff09;张量&#xff0c;out将是&#xff08;n x p&#xff09;张量。 input&#xff08;张量&#xff0…

栈回溯之CmBacktrace

简介 CmBacktrace &#xff08;Cortex Microcontroller Backtrace&#xff09;是一款针对 ARM Cortex-M 系列 MCU 的错误代码自动追踪、定位&#xff0c;错误原因自动分析的开源库。主要特性如下&#xff1a; 支持的错误包括&#xff1a; 断言&#xff08;assert&#xff09;…

Matplotlib数据可视化综合应用Matplotlib图形配置在线闯关_头歌实践教学平台

Matplotlib数据可视化综合应用图形配置 第1关 配置颜色条第2关 设置注释第3关 自定义坐标刻度第4关 配置文件与样式表 第1关 配置颜色条 任务描述 本关任务&#xff1a;使用colorbar绘制一个热成像图。 编程要求 在右侧编辑器Begin-End处补充代码&#xff0c;根据输入数据绘制…

P1529 [USACO2.4] 回家 Bessie Come Home 题解

文章目录 题目描述输入格式输出格式样例样例输入样例输出 提示完整代码 题目描述 现在是晚餐时间&#xff0c;而母牛们在外面分散的牧场中。 Farmer John 按响了电铃&#xff0c;所以她们开始向谷仓走去。 你的工作是要指出哪只母牛会最先到达谷仓&#xff08;在给出的测试数…

【数据结构】单链表之--无头单向非循环链表

前言&#xff1a;前面我们学习了动态顺序表并且模拟了它的实现&#xff0c;今天我们来进一步学习&#xff0c;来学习单链表&#xff01;一起加油各位&#xff0c;后面的路只会越来越难走需要我们一步一个脚印&#xff01; &#x1f496; 博主CSDN主页:卫卫卫的个人主页 &#x…