Spring IoC——依赖注入

Spring IoC——依赖注入

1. 依赖注入的介绍

DI,也就是依赖注入,在容器中建立的 bean (对象)与 bean 之间是有依赖关系的,如果直接把对象存在 IoC 容器中,那么就都是一个独立的对象,通过建立他们的依赖关系,才能拿出一个对象,然后与它建立依赖关系的对象就也可以使用,在 Spring 的 IoC 容器中,通过配置可以明确各个 Bean之间的依赖关系当一个 Bean 需要另一个 Bean 时,IoC 容器会自动将依赖的 Bean 注入进来,这个过程就是依赖注入。

2. 三种注入方式

2.1. 属性注入

属性注入直接通过@Autowired来实现的,直接加在属性上就可以完成注入

@Controller public class UserController { @Autowired private UserService userService; public void say(){ System.out.println("UserController"); userService.say(); } }

2.2. 构造方法注入

构造方法注入是通过在类的构造方法中完成注入

@Controller public class UserController { private UserService userService; private UserController(UserService userService) { this.userService = userService; } public void say() { System.out.println("UserController"); userService.say(); } }

如果说有多个构造方法的话,就需要指明需要使用哪个构造方法完成注入

为什么会空指针呢

如果有多个构造方法的话,默认是使用无参的构造方法的,可以通过@Autowired来指明使用哪个构造方法完成注入

@Controller public class UserController { private UserService userService; private UserController(){ } @Autowired private UserController(UserService userService) { this.userService = userService; } public void say() { System.out.println("UserController"); userService.say(); } }

关于传参:

交给 Spring 管理的对象,如果有参数,可以自己指定参数,如果没有指定,Spring 就会根据名称或者类型,从容器中查找对象,并注入进来

2.3. setter 注入

setter 注入是需要在 set 方法上加上@Autowired的,不能省略

@Autowired private void setUserService(UserService userService){ this.userService = userService; }

2.4. 三种方式的对比

属性注入:

优点:简洁,使用方便

缺点:不能注入一个 final 修饰的属性

构造方法注入:

优点:

  1. 可以注入 final 修饰的属性
  2. 注入的对象不会被修改
  3. 依赖对象在使用前一定会被初始化,构造方法是在类加载时就会执行的
  4. 通用性好,构造方法是 JDK 支持的,换任何框架都适用

setter 注入:

优点:方便在类实例之后,重新对该对象进行配置或者注入

缺点:

  1. 不能注入 final 修饰的属性
  2. 注入的对象可能会被改变,因为 setter 方法可能会被多次调用,就会有被修改的风险

3. @Autowired 存在的问题

Autowired 如果是同样类型有多个名称的对象时,按照名称来注入,如果只有一个对象,就直接注入,无论名称是否能对上

来看多个对象:

可以通过@Primary来指定默认使用哪个 bean 来装配

@Primary @Bean public UserInfo userInfo1(){ return new UserInfo("lisi1",20); }

还可以通过@Qualifier@Autowired配合使用来指定默认使用哪个 bean

当传入的参数也存在相同类型的对象时,也可以指定参数的默认值

@Bean public UserInfo userInfo(@Qualifier("name1") String name3){ return new UserInfo(name3,20); }

如果不使用 @Autowired的话还可以使用 @Resource注解来指定

@Autowired@Resource的区别:

  1. @Autowired 是Spring 框架提供的注解,@Resource 是 JDK 提供的注解
  2. @Autowired 默认是按照类型注入,@Resource 默认是按照名称注入
  3. @Autowired 优先按照类型匹配,如果类型相同再看名称,@Resource 前提也是要类型匹配,只不过是名称匹配的优先级更高:例如,有一个UserService类,需要注入一个UserRepository,如果使用@Resource注解并且指定了一个名称(如@Resource(name = "userRepo")),Spring 会首先查找名称为userRepoUserRepository类型的 Bean。只有在找不到这个名称对应的 Bean 时,才会去查找类型为UserRepository的 Bean,而不管其名称是什么。

@Autowired 的装配顺序:

我的主页

Read more

《算法闯关指南:优选算法--二分查找》--21.山峰数组的的峰顶索引,22.寻找峰值

《算法闯关指南:优选算法--二分查找》--21.山峰数组的的峰顶索引,22.寻找峰值

🔥草莓熊Lotso:个人主页 ❄️个人专栏:《C++知识分享》《Linux 入门到实践:零基础也能懂》 ✨生活是默默的坚持,毅力是永久的享受。 🎬博主简介: 目录 前言: 21. 山峰数组的的峰顶索引 解法(二分查找): 算法思路: C++算法代码: 算法总结&&笔记展示: 22. 寻找峰值 解法(二分查找): 算法思路: C++算法代码: 算法总结&&笔记展示: 结尾: 前言: 聚焦算法题实战,系统讲解三大核心板块:优选算法:剖析动态规划、二分法等高效策略,学会寻找“最优解”。 递归与回溯:掌握问题分解与状态回退,攻克组合、排列等难题。 贪心算法:理解“

By Ne0inhk
初探算法的魅力——【暴力枚举】

初探算法的魅力——【暴力枚举】

点击下面查看作者专栏🔥🔥C语言专栏🔥🔥🌊🌊编程百度🌊🌊🌠🌠如何获取自己的代码仓库🌠🌠 🌐索引与导读 * 暴力枚举(BF)的概念 * 暴力枚举的算法步骤 * 例题讲解 * 经典案例讲解一:百鸡问题 * 题目解析 * 思路方案 * 经典案例讲解二:盛最多水的容器 * 暴力枚举算法 * 最优解 * 经典案例讲解三:两数之和 * 经典案例讲解四:2025 * 💻 代码实现 * 希望读者多多三连 * 给小编一些动力 * 蟹蟹啦! 暴力枚举(BF)的概念 暴力枚举也称为穷举法,是计算机算法中最基础、最直观,但也是最费劲的一种解题思路 像我们平时没有最优解的算法题,往往都可以通过暴力枚举去算出最终结果 * 核心思想 不靠巧妙的技巧,而是利用计算机强大的计算能力,把所有可能的情况列举出来,一个一个去验证,直到找到正确答案 暴力枚举的算法步骤 * 列举 :确定解空间的范围,列出所有可能的解候选者 * 检验 :对每一个候选者进行判断,看它是否满足题目

By Ne0inhk
【优选算法必刷100题:专题五】(位运算算法)第033~38题:判断字符是否唯一、丢失的数字、两整数之和、只出现一次的数字 II、消失的两个数字

【优选算法必刷100题:专题五】(位运算算法)第033~38题:判断字符是否唯一、丢失的数字、两整数之和、只出现一次的数字 II、消失的两个数字

🎬 个人主页:艾莉丝努力练剑 ❄专栏传送门:《C语言》《数据结构与算法》《C/C++干货分享&学习过程记录》 《Linux操作系统编程详解》《笔试/面试常见算法:从基础到进阶》《Python干货分享》 ⭐️为天地立心,为生民立命,为往圣继绝学,为万世开太平 🎬 艾莉丝的简介: 🎬艾莉丝的算法专栏简介: 文章目录 * 常见位运算总结 * 1 ~> 刷前必刷题单 * 2 ~> 博主手记 * 033 判断字符是否唯一 * 1.1 解法(位图的思想): * 1.2 算法实现 * 1.3 博主手记 * 034 丢失的数字 * 2.1 解法:位运算 * 2.2 算法实现

By Ne0inhk
【C语言】排序算法——快速排序详解(含多种变式)!!!

【C语言】排序算法——快速排序详解(含多种变式)!!!

【C语言】排序算法——快速排序详解(含多种变式)!!! * 前言 * 一 、快速排序(初阶) * 1. 视频演示 * 2. 算法思想 * 3. 实现思路 * (1)定key值 * (2)大小交换 * (3)循环 * (4)交换key * (5)分割区间 * (6)结束 * 4. 实现代码 * 二 、快速排序(中阶) * 1. 存在的问题 * 2. 优化(三数取中) * 3. 实现代码(中阶) * 三 、快速排序(高阶) * 1. 仍存在的问题 * 2. 优化(小区间优化) * 3. 实现代码(高阶)

By Ne0inhk