文章目录
以下这种是手动装配,每个属性都得设置才生效
自动装配:就是不设置它也能给我自动去找到这个机制
- 自动装配是Spring满足bean依赖一种方式!
- Spring会在上下文中自动寻找,并自动给bean装配属性!
在Spring中有三种装配的方式
- 在xml中显示的配置
- 在java中显示配置
- 隐式的自动装配bean【重要】
测试
环境搭建:一个人有两个宠物!
ByName自动装配
byName:会自动在容器上下文中查找,和自己对象set方法后面的值对应的beanid !
byName:会自动在容器上下文中查找,和自己对象set方法后面的值对应的beanid !
ByType自动装配
byType:会自动在容器上下文中查找,和自己对象属性类型相同的bean !
报错原因:byTybe必须保证这个类型全局唯一,它就会给你自动装配;
而byName只要你这个set名字后面跟里的id相同就可以自动注入
去掉bean里的id也能正常执行,这是byType的好处,不用给名字也能正常跑,因为byType是根据类型来的(根据bean里的class类型)
class=“com.guangyou.pojo.Cat”
class=“com.guangyou.pojo.Dog”
小结:
使用byname的时候,需要保证所有bean的id唯一,并且这个bean需要和自动注入的属性的set方法的值一致!
使用bytype的时候,需要保证所有bean的class唯一,并且这个bean需要和自动注入的属性的类型一致!
使用注解实现自动装配
@Autowired注解
要使用注解须知:
- 导入约束: context约束
- 配置注解的支持:context:annotation-configl
<?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/>
</beans>
beans.xml
<?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/>
<bean id="dog" class="pojo.Dog"/>
<bean id="cat" class="pojo.Cat"/>
<bean id="person" class="pojo.Person"/>
</beans>
测试:MyTest
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import pojo.Person;
public class MyTest {
@Test
public void test1(){
ApplicationContext context = new ClassPathXmlApplicationContext("beans.xml");
Person person = context.getBean("person", Person.class);
person.getCat().shout();
person.getDog().shout();
System.out.println(person.getDog());
System.out.println(person.getCat());
System.out.println(person.getDog().hashCode());
System.out.println(person.getCat().hashCode());
}
}
Autowired
直接在属性上使用即可! 也可以在set方式上使用!
使用Autowired 我们可以不用编写Set方法了,前提是你这个自动装配的属性在IOC (Spring)容器中存在,且符合名字bytype ! 也就是这个bean需要和自动注入的属性的set或get方法的值一致!
科普:
@Nullable字段标记了这个注解,说明这个字段可以为null ; 正常为空是会报错的
public @interface Autowired {
boolean required() default true;
}
如果显示定义了Autowired的required属性为false,说明这个对象可以为null,否则不允许为空
public class Person {
//如果显示定义了Autowired的required属性为false,说明这个对象可以为null,否则不允许为空
@Autowired(required = false)
private Cat cat;
@Autowired
private Dog dog;
private String name;
}
有一种情况名字不相同,类型也不相同,存在多个的情况下
清理一下Maven
多个dog,cat,也就是多个对象,自动装配无法实现了,但是还想使用自动装配,加一个@Qualifier,给它指定实现一个容器中装配的值
报错原因:通过名字匹配不到,通过类型也匹配不到
解决方法:手动添加@Qualifier
总结:
如果@Autowired自动装配的环境比较复杂,自动装配无法通过一个注解【@Autowired】完成的时候、我们可以使用@Qualifier(value=“xxx”)去配置@Autowired的使用,指定一个唯一的bean对象注入!
@Resource注解
名字不一样,最后类型是唯一的也可以
先通过名字去找,找不到再通过类型去找,两个都失败才会报错
指定装配
小结 : Resource和@ Autowired的区别:
- 都是用来自动装配的,都可以放在属性字段上
- @Autowired通过byType的方式实现,而且必须要求这个对象存在!【常用】
- @Resource默认通过byName的方式实现,如果找不到名字,则通过byType实现! 如果两个都找不到的情况下,就报错!【常用】
- 执行顺序不同:@Autowired通过byType的方式实现。@Resource默认通过byname的方式实现