Spring总结——控制反转,注入(配置和注解两种方式)
本文内容纲要:Spring总结——控制反转,注入(配置和注解两种方式)
一、Spring的容器:
1.什么是控制反转:传统的方法,当某个java对象A需要调用对象B时,是由调用者(对象A)通过new关键字来创建对象B的(也可以说类A依赖类B),而在Spring中,则是由spring完成创建的,所以“控制反转”了。那么当需要更改类信息时,只要改Spring的配置文件就行了,这样我们就明白了:之所以要用Spring来创建新对象的目的就是它能降低类与类之间的耦合度。
2.容器:
Spring容器是Spring的核心。
实例化一个spring容器,容器会自动预初始化所有Bean实例,然后通过getBean()方法取得某个对象实例。
ApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml"); //实例化一个Spring容器,Boss boss = (Boss) ac.getBean("boss"); //取得对象boss
二、手动注入:
**1.setter方法注入。**格式为:
<bean id=" " class=" "> <property name=" " value=" " />
<property name=" " value=" " />
</bean>
例子:
<bean id="boss" class="wang.spring.Boss"> <property name="car" ref="car"/>
<property name="office" ref="office" />
</bean>
<bean id="office" class="wang.spring.Office">
<property name="officeNo" value="002"/>
</bean>
<bean id="car" class="wang.spring.Car" scope="singleton">
<property name="brand" value=" 红旗 CA72"/>
<property name="price" value="2000"/>
</bean>
2.构造函数注入:必须写有参的构造函数。index="0"表示构造函数的第一个参数。
<bean id="car" class="wang.spring.Car "> <constructor-arg index=" 0" type=“int” value=" 001” />
<constructor-arg index=" 1" type=“String” value=" baoma” />
</bean>
利用上面代码,可以新建一个实例car,并给它的属性赋值。
三、依赖注入:当前类A需要用到类B的对象实例,则要通过类B的构造器new B(),则说类A依赖类B。(也就是说当前类引用其他类的对象)
<beans> <bean id=”bean1” class=”……”>
<property name=”属性1” value=”……”/>
</bean>
<bean id=”bean2” class=”……”>
<property name=”bean1” ref=”bean1”/>
</bean>
</beans>
四、集合的注入:
Set集合注入:
<bean id=”……” class=”……”> <set>
<value>value1</value>
<value>value2</value>
……
</set>
</bean>
Lsit集合注入:
<bean id=”……” class=”……”> <list>
<value>value1</value>
<value>value2</value>
……
</list>
</bean>
Map集合注入:
<bean id=”……” class=”……”> <map>
<entry key=”key1” value=”value1”>
<entry key=”key2” value=”value2”>
……
</map>
</bean>
五、自动注入:分配置文件自动注入和注解自动注入
A: 配置文件自动注入
通过bean里的属性autowire可以自动注入实例。
no:不使用自动装配。这是默认配置。
byName:根据属性自动装配,BeanFactory会查找容器中所有的Bean,找出id属性与属性名同名的Bean来完成注入。如果没有找到匹配的Bean,Spring则不会进行任何注入。
byType:根据属性类型自动装配,BeanFactroy会查找容器中所有的 Bean,如果一个正好与依赖属性类型相同的Bean,就会自动注入这个属性。
如果有多个这样的Bean则会抛出异常。如果没有这样 的Bean则什么也不会发生,属性不会被设置。
<beans> <bean class="dao.OrderDaoImpl" autowire="byName"></bean>
<bean class="dao.ItemDaoImpl"></bean>
<bean id="storeService" class="service.StoreServiceImpl"></bean>
</beans>
B: 注解自动注入
注解可以分为两大类。JSR-250规范注解方式 和 Spring自带的注解方式。
通过注解的方式装配时,必须在配置文件中添加一个bean,它其实是一个注解处理器,用于解析注解。
JSR-250规范注解方式的处理器:
<bean class="org.springframework.context.annotation.CommonAnnotationBeanPostProcessor"/>
Spring自带的注解方式的处理器:
<bean class="org.sprinframework.beans.factory.annotation. AutowiredAnnotationBeanPostProcessor"/>
当然,我们有更方便的方法,两种注解方式都可以用下面的方式隐式得注册注解处理器:
<context:annotation-config>
1.JSR-250规范注解方式:
@Resource
默认是按照名称匹配(byName),但它有两个属性,name和type。分别可以指定自动匹配的类型。
标注在成员变量,setter方法,构造函数上都可以。
public class Boss { // 自动注入类型为 Car 的 Bean
@Resource
private Car car;
// 自动注入 bean 名称为 office 的 Bean
@Resource(name = "office")
private Office office;
}
2.Spring自带的注解方式:
@Autowired
按照类型匹配(byType)
标注在成员变量,setter方法,构造函数上都可以。
因为这种注解是按照类型注入的,所以要有多个同类型的对象,则会出现异常。此时我们可以用**@Qualifier**指定对象的名称,两者结合使用,便可以确定一个对象。
public class Boss { @Autowired
@Qualifier("office")
private Office office;
//当在成员变量上标注时,不需要写setter方法…
}
@Qualifier的标注对象是成员变量、方法入参、构造函数入参。正是由于注释对象的不同,所以 Spring 不将 @Autowired 和@Qualifier 统一成一个注释类。(@Qualifier只能结合@Autowired使用,不能单独使用)
注意:常见的一个误区是,在这时用注解自动注入时就完全不用配置文件了,这是错误的。此时的配置文件仍是这样的,它用来定义bean。若想减掉配置文件,则需要看下面的零配置,通过注解取代定义bean。
<beans> <bean class="dao.OrderDaoImpl"></bean>
<bean class="dao.ItemDaoImpl"></bean>
<bean id="storeService" class="service.StoreServiceImpl"></bean>
</beans>
六、实现零配置:
我们可以通过上面两种注解方式,在bean中实现自动注入。但是bean还得在xml文件中通过
Spring提供如下几个Annotation来标注Spring Bean:
@Component标注一个普通的Spring Bean;
@Controller:标注一个控制器组件类;
@Service:标注一个业务逻辑组件类;
@Repository:标注一个Dao组件;
目前Component可在各层通用。
@Componentpublic class Boss {
@Autowired
private Car car;
@Autowired
private Office office;
…
}
这时,bean.xml文件中就不必用
<context:component-scan base-package="com.baobaotao"/>
本文内容总结:Spring总结——控制反转,注入(配置和注解两种方式)
原文链接:https://www.cnblogs.com/wangerxiansheng/p/3836399.html
以上是 Spring总结——控制反转,注入(配置和注解两种方式) 的全部内容, 来源链接: utcz.com/z/296413.html