1、 bean的作用域
-
代理模式(Spring默认机制):get到的都是同一个对象!
<bean id="user2" class="com.kuang.pojo.User" c:age="18" c:name="张三" scope="singleton"/>
-
原型模式:每次从容器中get的时候,都会产生一个新的对象!
<bean id="user2" class="com.kuang.pojo.User" c:age="18" c:name="李四" scope="prototype"/>
-
其余的request、session、application、这些个只能在web开发中使用。
1.1 别名
<!--别名,如果添加了别名,我们也可以使用别名获取到-->
<alias name="user" alias="userNew"></alias>
1.2 Bean的配置
<!--
id:bean的唯一标识符,相当于我们所学的对象名;
class:bean对象所对应的全限命名:包名+类名;
name:也是别名,而且name可以同时取多个别名,逗号分割
-->
<bean id="userT" class="com.kuang.pojo.UserT" name="user2,u2">
<property name="name" value="哈哈"/>
</bean>
1.3 import
这个import,一般用于团队开发使用,他可以将多个配置文件,导入合并为一个。
假设,现在项目中有多个人开发,这三个人负责不同的类开发,不同的类需要注册在不同的bean中,我们可以利用import将所有人的beans.xml合并为一个总的applicationContext.xml!
- 张三(beans1.xml)
- 李四(beans2.xml)
- 王五(beans3.xml)
- applicationContext.xml
<import resource="beans1xml"/>
<import resource="beans2.xml"/>
<import resource="beans3.xml"/>
使用的时候,直接使用总的配置就可以了。
2、 Bean的自动装配
- 自动装配是Spring满足bean依赖的一种方式!
- Spring会在上下文中自动寻找,并自动给bean装配属性!
在Spring中有三种装配的方式:
- 在xml中显式配置;
- 在java中显式配置;
- 隐式的自动装配bean【重要】
2.1 测试
环境搭建:一个人有两个宠物!
2.2 ByName自动装配
<bean id="cat" class="edu.xalead.pojo.Cat"></bean>
<bean id="dog" class="edu.xalead.pojo.Dog"></bean>
<!--
byName:会自动在容器上下文中查找和自己对象set方法后面的值对应的beanid!
-->
<bean id="people" class="edu.xalead.pojo.People" autowire="byName">
<property name="name" value="王麻子"/>
</bean>
2.3 ByType自动装配
<bean id="cat" class="edu.xalead.pojo.Cat"></bean>
<bean id="dog" class="edu.xalead.pojo.Dog"></bean>
<!--
byType:会自动在容器上下文中查找,和自己对象属性类型相同的bean!必须保证类型全局唯一。
-->
<bean id="people" class="edu.xalead.pojo.People" autowire="byType">
<property name="name" value="李四"/>
</bean>
小结:
- byName的时候,需要保证所有bean的id唯一,并且这个bean需要和自动注入的属性的set方法的值一致!
- byType的时候,需要保证所有bean的class唯一,并且这个bean需要和自动注入的属性的类型一致!
2.4 使用注解实现自动装配
jdk1.5开始支持注解,Spring2.5开始支持注解。
要使用注解须知:
-
导入约束:context约束。
-
配置注解的支持:context:annot-config/
<?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>
@Autowired
直接在属性上使用即可!也可以在set方式上使用!
使用Autowired我们可以不用编写Set方法了,前提是你这个自动装配的属性在IOC(Spring)容器中存在,且符合名字byName!
科普:
@Nullable 字段标记了这个注解,说明这个字段可以为null
public People(@Nullable String name){
this.name = name;
}
public @interface Autowired {
boolean required() default true;
}
测试代码:
public class People {
//如果显式定义了Autowired的required属性为false,说明这个对象可以为null,否则不允许为空
@Autowired(required = false)
private Dog dog;
@Autowired
private Cat cat;
private String name;
}
如果@Autowired自动装配的环境比较复杂,自动装配无法通过一个注解@Autowired完成的时候,我们可以使用@Qualifier(value=“xxx”)去配置@Autowired的使用,指定一个唯一的bean对象注入!
public class People {
@Autowired
@Qualifier(value="dog11")
private Dog dog;
@Autowired
@Qualifier(value="cat11")
private Cat cat;
private String name;
}
@Resource注解
public class People {
@Resource(name = "cat2")
private Cat cat;
}
小结:
@Resource和@Autowired的区别与联系:
-
都是用来自动装配的,都可以放在属性字段上;
-
@Autowired通过byType的方式实现,而且必须要求这个对象存在!【常用】
-
@Resource默认通过byName的方式实现,如果找不到名字,则通过byType实现!如果两个都找不到的情况下,就报错!
-
执行顺序不同:@Autowired通过byType的方式实现,@Resource默认通过byName的方式实现。
欢迎访问我的个人博客看完整版Spring5:http://www.ayjup.cn