Springbean的几种注入方式都了解吗
作者:java圈 发布时间:2023-01-09 05:37:10
Spring注入方式可以分为三类,xml注入、注解注入、BeanDefinition注入;用法上可以分为三种,但是底层实现代码都是统一BeanFactory,这三种也有联系xml注入和annotation注入都是依赖BeanDefinition扩展的接口,注解也是从xml过渡过来的,我们简单的看下这三种的写法。
XML注入
在springboot框架没有出来之前,xml配置被大量的使用,配置过程比较繁琐,但是对代码的侵入性较小,配置和代码分离操作。
实体定义
定义两个属性id,name,并实现get/set方法,重写toString方法,方便看打印结果。
public class UserXml {
private String id;
private String name;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "User{"
"id='" id '\''
", name='" name '\''
'}';
}
}
xml定义
在resources下新建目录META-INF下建spring-bean.xml文件,并填充对应的bean配置,bean需要配置id或者name值,IOC容器唯一即可,class配置定义的实体路径,对应的property设置初始化属性。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
https://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="user" class="cn.cnzcb.spring.bean.UserXml">
<property name="id" value="11"/>
<property name="name" value="java圈"/>
</bean>
</beans>
输出
创建一个BeanFactory对象,用ClassPathXmlApplicationContext实例化,简单说一下BeanFactory作为IOC容器的底层基础,可以说IOC容器就是BeanFactory,ClassPathXmlApplicationContext是IOC容器的功能扩展;ClassPathXmlApplicationContext需要传入资源文件的路径,在通过getBean方法获取具体的实体类,就是结果输出。
//xml注入
BeanFactory classPathXmlApplicationContext = new ClassPathXmlApplicationContext("classpath:/META-INF/spring-bean.xml");
UserXml userXml = classPathXmlApplicationContext.getBean(UserXml.class);
System.out.println("userXml XML注入对象:" userXml);
注解注入
注解是在spring2.0.3之后才出现的,大量应用也是在springboot的普及下,大家才慢慢接受。其主要好处就是操作简单,通过简单的注解就可以标识成bean组件,而且扩展了各种层次的注解,比如@Service、@Service、@Repository,都是基于@Component注解实现派生。
实体定义
实体通XML实体作用类似,这里新建一个类,用去区分不同的bean实现方式。
public class UserAnnotation {
private String id;
private String name;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "User{"
"id='" id '\''
", name='" name '\''
'}';
}
注解配置
正常情况下我们是通过标准注解@Configuration进行扫描注入,我们这里直接配置类即可,在这个类里面实例化bean组件,并进行初始化操作。
@Configuration
public class UserConfiguration {
@Bean
public UserAnnotation userAnnotation(){
UserAnnotation userAnnotation = new UserAnnotation();
userAnnotation.setId("11");
userAnnotation.setName("java圈");
return userAnnotation;
}
}
输出
AnnotationConfigApplicationContext也是BeanFactory的一种实现,和ClassPathXmlApplicationContext功能类似,只是加载渠道不一样,把定义的配置类注册到IOC容器,调用register方法,这里需要注意,下一步需要调refresh方法就行bean的装载工作,然后通过getBean获取具体的实体,就行输出。
//注解注入
AnnotationConfigApplicationContext annotationConfigApplicationContext = new AnnotationConfigApplicationContext();
annotationConfigApplicationContext.register(UserConfiguration.class);
annotationConfigApplicationContext.refresh();
UserAnnotation userAnnotation = annotationConfigApplicationContext.getBean(UserAnnotation.class);
System.out.println("UserAnnotation注解注入" userAnnotation);
BeanDefinition注入
BeanDefinition是BeanFactory的底层实现,包括上面提到的方式,底层也是基于BeanDefinition实现的,一个bean组件对应一个BeanDefinition,但是实际操作过程中不会这个用,只是仅供参考。
实体定义
实体通XML实体作用类似,这里新建一个类,用去区分不同的bean实现方式。
public class UserBeanDefinition {
private String id;
private String name;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "User{"
"id='" id '\''
", name='" name '\''
'}';
}
}
输出
通过BeanDefinitionBuilder的genericBeanDefinition实例化一个构造器,传入的参数就是实体类,构建之后做初始化操作,之后BeanDefinition声明调用getBeanDefinition方法,通过getPropertyValues回去bean的具体参数进行结束输出。
//BeanDefinition注入
BeanDefinitionBuilder definitionBuilder = BeanDefinitionBuilder.genericBeanDefinition(UserBeanDefinition.class);
definitionBuilder.addPropertyValue("id", "11");
definitionBuilder.addPropertyValue("name", "java圈");
BeanDefinition beanDefinition = definitionBuilder.getBeanDefinition();
String beanClassName = beanDefinition.getBeanClassName();
MutablePropertyValues mutablePropertyValues = beanDefinition.getPropertyValues();
String id = mutablePropertyValues.getPropertyValue("id").getValue().toString();
String name = mutablePropertyValues.getPropertyValue("name").getValue().toString();
System.out.println("BeanDefinition注入对象UserBeanDefition{id=" id ",name=" name "}");
结果输出
输出结果分别是xml注入、annotation注入,BeanDefinition注入。
userXml XML注入对象:User{id='11', name='java圈'}
UserAnnotation注解注入User{id='11', name='java圈'}
BeanDefinition注入对象UserBeanDefition{id=11,name=java圈}
源代码:https://github.com/itrickzhang/spring-demo
来源:https://blog.csdn.net/zhangchangbin123/article/details/103983276
猜你喜欢
- 本文实例讲述了简单记事本java实现代码。分享给大家供大家参考。具体如下:完整代码如下:import java.awt.*;import j
- 本文实例为大家分享了java简单实现斗地主发牌的具体代码,供大家参考,具体内容如下问题:参考斗地主的游戏规则,完成一个发牌的功能(54张牌,
- 要实现摇一摇的功能,类似于微信的摇一摇方法1:通过分析加速计数据来判断是否进行了摇一摇操作(比较复杂)方法2:iOS自带的Shake监控AP
- Hibernate是一个彻底的ORM(Object Relational Mapping,对象关系映射)开源框架。我们先看一下官方文档所给出
- Web UI项目中, 很多 Spring controller 视图函数直接返回 html 页面, 还有一些视图函数是要重定向或转发到其他的
- 好久就想着好好搭建一个ssm框架,自己以后用也方便吧,但是最近的事真的是很多,很多事情都没有去干,有时候自己会怀疑一下人生自己该不该去做程序
- 接收JSON浏览器传来的参数,可以是 key/value 形式的,也可以是一个 JSON 字符串。在 Jsp/Servlet 中,我们接收
- synchronized 和 Reentrantlock多线程编程中,当代码需要同步时我们会用到锁。Java为我们提供了内置锁(synchr
- 本文实例讲述了Java面向对象程序设计:类的定义,静态变量,成员变量,构造函数,封装与私有,this概念与用法。分享给大家供大家参考,具体如
- 背景前段时间同事碰到一个问题,需要在 SpringCloud 的 Feign 调用中使用自定义的 URL;通常情况下是没有这个需求的;毕竟都
- 一、介绍在实际的软件项目开发过程中,我可以很负责任的跟大家说,如果你真的实际写代码的时间超过5年,你对增删改查这类简单的功能需求开发,可以说
- java解析json数组最简单的json数组[ { &quo
- 弃用内容先来纠正一个误区。主要之前在版本更新介绍的时候,存在一些表述上的问题。导致部分读者认为这次的更新是Datasource本身初始化的调
- 目录简介强引用软引用弱引用虚引用简介从JDK1.2版本开始,把对象的引用分为四种级别,从而使程序能更加灵活的控制对象的生命周期。这四种级别由
- 本文实例为大家分享了Java文件操作的具体代码,供大家参考,具体内容如下简介本程序主要采用了FileInputStream和FileOutp
- mport java.text.DecimalFormat; DecimalFormat &nb
- 五子棋游戏(Java),供大家参考,具体内容如下思路:1.首先创建一个棋盘,建立一个二维数组,此文中为一个15*15的二维数组,2.初始化棋
- 好久没有做web了,JSON目前比较流行,闲得没事,所以动手试试将对象序列化为JSON字符(尽管DotNet Framework
- 编程是一门艺术,大批量的改动显然是非常丑陋的做法,用心的琢磨写的代码让它变的更美观。在软件开发系统中,**“方法的请求者
- 简述:JRebel是一款JVM插件,它使得Java代码修改后不用重启系统,立即生效。IDEA上原生是不支持热部署的,一般更新了 Java 文