Spring自动装配+注解开发

本文介绍了Spring框架中的自动装配原理,重点讲解了XML配置和注解驱动的装配方式,包括`@Autowired`、`@Qualifier`等注解的使用,以及如何在测试中验证装配效果。同时讨论了xml和注解在bean管理中的优缺点。
摘要由CSDN通过智能技术生成

自动装配

Spring会在上下文中自动寻找,并自动bean装配属性,在Spring中有3种装配的方式,Spring的自动装配主要说的是第3个

  1. java中显示配置
  2. xml中显示配置
  3. 隐式的自动装配bean

测试自动装配

  1. 搭建环境(人有2个宠物,猫和狗)
    在这里插入图片描述

  2. bean标签加上autowire属性,下面3个代码块的效果是一样的

    <bean id="person" class="com.bkms.pojo.Person">
        <property name="name" value="Johnson"/>
        <property name="cat" ref="cat"/>
        <property name="dog" ref="dog"/>
    </bean>
    <bean id="person" class="com.bkms.pojo.Person" autowire="byName">
        <property name="name" value="Johnson"/>
    </bean>
    <bean id="person" class="com.bkms.pojo.Person" autowire="byType">
        <property name="name" value="Johnson"/>
    </bean>
  1. byName会自动在容器上下文中查找,和自己对象set方法后面的值对应的beanid,通俗来说就是关联对象set的参数
    public Cat getCat() {
        return cat;
    }

    public void setCat(Cat cat) {
        this.cat = cat;
    }

    public Dog getDog() {
        return dog;
    }

    public void setDog(Dog dog) {
        this.dog = dog;
    }
  1. byName必须保证id必须唯一不能重重复,byType必须保证类型全局唯一,就是class属性不能出现重复

注解实现自动装配

  1. 导入约束,context约束,aop导入的方法和context一样
<?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:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        https://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context
        https://www.springframework.org/schema/context/spring-context.xsd">
  1. 配置注解的支持
    <!--注解支持-->
    <context:annotation-config/>

注解开发

Spring4之后,注解开发的前提是需要导入aop包

常见注解

  1. 加入注解@Autowire,加在set方法前也能注入,其实用注解的话set方法也可以不写,如果@Autowire不能唯一装配属性,则使用@Qualifer
public class Person {
    //注解自动装配需要xml中的id和成员变量名一致
    @Autowired
    private Cat cat;
    @Autowired
    private Dog dog;
    private String name;
}
  1. @Nullable字段标记了这个注解,说明这个字段可以为null
    public void setName(@Nullable String name) {
        this.name = name;
    }
  1. @Qualifier指定装配的id值,只允许同一类型指定id值
    @Autowired
    @Qualifier(value = "cat")
    private Cat cat;
  1. @Resource,使用较少

代码测试

  1. 注解驱动和指定扫描包
<?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:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        https://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context
        https://www.springframework.org/schema/context/spring-context.xsd">

    <!--注解驱动-->
    <context:annotation-config/>
    <!--指定扫描的包,包下的注解就能生效-->
    <context:component-scan base-package="com.bkms"/>
    
</beans>
  1. @Component注解的使用,bean注入
//@Component组件 效果相当于<bean id="user" class="com.bkms.pojo.User"/>
//使用注解实现了装配
@Component
public class User {
    public String name="Philip";
}
  1. @Value注解的使用,属性注入
public class User {
    //@Value("Johnson") 效果相当于<properties name="name" value="Johnson">
    @Value("Johnson")
    public String name;
}
  1. 衍生注解,在web开发中会按照mvc三层架构分层
@Repository
public class UserDao {
}
@Controller
public class UserController {
}                                                                               
  1. 小结xml和注解
  • xml是最万能的,适用于任何场景,维护及其方便
  • 注解维护不方便,使用注解无法使用beans.xml之间的引用
  • xml适合管理bean,注解只负责完成属性的注入
  • 想要让注解生效就需要开启注解的支持,开启扫描包的标签
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

muskfans

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值