详解Spring 中 Bean 对象的存储和取出
作者:风能保暖内裤 发布时间:2023-08-06 02:42:46
由于 Spring 拥有对象的管理权,所以我们也需要拥有较为高效的对象存储和取出的手段,下面我们来分别总结一下:
存对象
配置文件
在存储对象之前,我们需要先配置一下 Spring 的扫描目录,这样 Spring 即可在正确的目录中识别出我们想要给交给 Spring 进行管理的对象
首先在项目中的 resources 目录下添加一个 xml 文件,名字可以自定义
随后在这个 xml 中添加如下代码,这段代码可以直接复制,但是要修改倒数第二行的 base-package 中的路径改成自己的路径
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:content="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd">
<? 下面这行代码是设置 spring 的扫描目录,base-package 中的路径 可以直接设置成我们代码中的根目录 ?>
<content:component-scan base-package="dir"></content:component-scan>
</beans>
类注释
在 Spring 中我们可以通过类注释或者方法注释来进行对象的存储,其中类注释是用的比较多的,类注释总共有 5 种:
@Conntroller,业务逻辑层
@Service,服务器存储
@Repository,仓库存储,可以用来操作数据库
@Component,项目组件层
@Configuration,配置层
这五种类注释的作用都是可以直接将这个类对象储存到 Spring 中,但是却有 5 种类注释,这么做的原因是:能够让我们看到类注释就能得知这个类的大致功用
命名规则
类注释中有两套命名规则
如果当前类名中前两个字母都是大写,那么存入 Spring 中的对象名字默认是类名
否则名字为第一个字母转为小写后的类名
除了上面 5 种类注释之外,还有方法注释
方法注释
方法注释就是将注释@Bean
加到方法上方,并且必须搭配类方法使用
作用:将这个方法返回的对象存入到 Spring 中
例如
@Controller
public class Student {
@Bean
private Student getStudent() {
return new Student();
}
}
通过 @Bean 注释存入 Spring 中的对象名字默认是方法名,我们也可以直接在 @Bean 后面直接加上参数指定这个对象的名字,例如
@Controller
public class Student {
@Bean(name="sb") // 设置对象的名字
private Student getStudent() {
return new Student();
}
}
取对象
在 Spring 中,获取 Spring 中的对象也有另一种叫法:对象装配
主要有三种对象装配的方式
属性注入
我们可以直接在成员变量中添加 @Autowired 注释, @Autowired 会优先匹配 Spring 中类名相同的对象,例如下面代码中的 user,Autowired 会优先按照 user 的类型在 spring 中进行匹配
@Controller
public class Student {
@Autowired
private User user;
@Bean(name="sb")
private Student getStudent() {
return new Student();
}
}
这种注入方式很简单也很快,但是缺点不少:
可移植性差,这个用法是建立在 IoC 容器上的,移植到其他框架上可能无法使用
无法注入不可变的对象,也就是 final 修饰的对象
因为 final 修饰的变量只有两个初始化时机,第一个是直接赋值,第二个是在类的构造方法中赋值,显然这种对象注入的方式无法满足其中一个条件
由于使用简单,容易滥用,所以比较容易被违背单一设计原则(即一个类只干一件事)
setter 注入
首先创建一个要注入的对象,然后通过「右键 — generate — setter」生成一个 setter 方法,最后在这个 setter 方法头顶上添加 @Autowired 注释
@Controller
public class Student {
private User user;
@Autowired // 通过 setter 注入
public void setUser(User user) {
this.user = user;
}
}
setter 注入的缺点:
由于是 setter 方法,所以可能多次调用,这就意味着这个对象可以被多次修改
依旧无法注入 final 修饰的对象,原因同上
构造方法注入
顾名思义,这是在构造方法上添加 @Autowired 注释来注入对象,如下
@Controller
public class Student {
private User user;
@Autowired
public Student(User user) {
this.user = user;
}
}
构造方法注入的优点:
由于是构造方法,只会执行一次,所以对象不会被重复更改
可以注入 final 修饰的对象(在构造方法中赋值)
JDK本身就支持构造方法,所以有更低的门槛,说人话:具有更强的可移植性
来源:https://blog.csdn.net/weixin_63519461/article/details/127855362


猜你喜欢
- 单例模式根据实例化对象时机的不同分为两种:一种是饿汉式单例,一种是懒汉式单例。私有的构造方法指向自己实例的私有静态引用以自己实例为返回值的静
- 本文实例为大家分享了Android仿iphone自定义滚动选择器的具体代码,供大家参考,具体内容如下一、多的不说,效果图,先走起二、实例源码
- 引言当我们通过@ConfigurationProperties注解实现配置 bean的时候,如果默认的配置属性转换无法满足我们的需求的时候,
- 实例如下所示:public class WebServiceHelper { /// <summary>  
- 目录1、通过session中的token验证步骤1:创建自定义注解步骤2:创建自定义 * (@slf4j是lombok的注解)步骤3:将自定
- 具体详细介绍请看下文:在使用文件进行交互数据的应用来说,使用FTP服务器是一个很好的选择。本文使用Apache Jakarta Common
- 本文研究的主要是Flask实现异步非阻塞请求功能,具体实现如下。最近做物联网项目的时候需要搭建一个异步非阻塞的HTTP服务器,经过查找资料,
- 这个问题困扰了很久,有些类不是controller在使用autowired注入的类显示为空,找到网上的方法是在类初始化时主动注入被Autow
- 最近在项目中,一个go服务给前端提供了一个接口,返回json格式数据,其中Int64字段会超出javascript Number可表示的最大
- 传统方式克隆羊问题现在有一只羊 tom,姓名为: tom,年龄为:1,颜色为:白色,请编写程序创建和 tom羊属性完全相同的10只羊。传统方
- 直接上代码:public class WeiXinFilter implements Filter{private static Logge
- 一、思路将分页所需的内容都放到一个实体类中分页数据所需要的实体类!内包含页码,页大小,总条数,总页数,起始行pagehelpr提供了这个类
- 404这个错误真的是一言难尽!不过大多是配置文件出错,认真修改还是可以的1.web.xml配置错误:默认首页没有写的,在web.xml添加一
- 本节向你展示如何在任务中发送数据给UI线程里的对象,这个特性允许你在后台线程工作,完了在UI线程展示结果。在UI线程定义一个HandlerH
- 1、图像灰度化:public Bitmap bitmap2Gray(Bitmap bmSrc) { // 得到图片的长和宽
- /// <summary> /// 安装的excel的版本,0为没有安装,大于1说明安装了多个. /// </summar
- 在微信的运营过程中难免会出现一些无法预料的事情,比如在
- 前言:Android开发中,自定义View实现自己想要的效果已成为一项必备的技能,当然自定义View也是Android开发中比较难的部分,涉
- 在学习C#中委托和事件时,产生一个疑问,类中定义的事件在类内部可以直接调用,而在类外部,事件却只能添加或移除委托方法比如下面这段代码,类Cu
- 1、定义常量(1)const修饰变量,以下两种定义形式在本质上是一样的。它的含义是:const修饰的类型为TYPE的变量value是不可变的