Spring IOC装配Bean过程解析
spring的依赖注入
spring主要支持两种依赖注入方式,分别是属性注入和构造函数注入。同时也支持工厂方法注入方式。
属性注入
属性注入的方式非常简单,即指通过setxxx()方法注入bean的属性值或依赖对象。如下实例
编写user类
public class user { private string username; private string address; public user() { } public user(string username, string address) { this.username = username; this.address = address; } public string getusername() { return username; } public void setusername(string username) { this.username = username; } public string getaddress() { return address; } public void setaddress(string address) { this.address = address; } @override public string tostring() { return "user{" + "username='" + username + '\'' + ", address='" + address + '\'' + '}'; } }
编写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:p="http://www.springframework.org/schema/p" xsi:schemalocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd"> <bean id="user" class="com.rookie.bigdata.domain.user"> <property name="username" value="张三"></property> <property name="address" value="北京"></property> </bean> </beans>
测试
applicationcontext applicationcontext=new classpathxmlapplicationcontext("injection/bean.xml");
user user=(user)applicationcontext.getbean("user");
system.out.println(user);
构造函数注入
构造函数注入是属性注入的另一种常用的注入方式。
xml配置方式如下
<bean id="user" class="com.rookie.bigdata.domain.user"> <constructor-arg name="username" value="李四"></constructor-arg> <constructor-arg name="address" value="上海"></constructor-arg> </bean>
注入参数
xml中含有5个特殊符号,分别是&,<,>,”,‘,如果配置文件中的注入值包含这些特殊的字符,就需要进行特殊的处理。有两种解决方法,其一:采用特殊标签,将包含特殊字符的字符串封装起来。其二:使用xml转义序列表示这些特殊字符。
<bean id="user" class="com.rookie.bigdata.domain.user"> <property name="username" value="张三"></property> <!-- <property name="address" value="北京"></property>--> <property name="address"> <value><![cdata[北京&通州]]></value> </property> </bean>
特殊字符 | 转义序列 | 特殊字符 | 转义序列 |
---|---|---|---|
< | < | “ | " |
> | > | ' | ' |
& | & |
基于注解的配置
<context:component-scan base-package="com.rookie.bigdata.annotation"></context:component-scan>
component-scan 的base-package属性指定一个需要扫描的基类包,spring容器会扫描这个基类包里面的所有的属性,并从类的注解信息中获取bean的定义信息。
如果想扫描特定的类,可以使用resource-pattern属性过滤出特定的类。如:
<context:component-scan base-package="com.rookie.bigdata" resource-pattern="annotation/*.class"></context:component-scan>
即spring仅会扫描基类包里annotation子包中的类。
通过使用resource-pattern发现,还是有很多时候并不满足要求,此时可以通过过滤表达式。如下:
类别 | 示例 | 说明 |
---|---|---|
annotation | com.rookie.bigdata.xxxannotation | 所有标注了xxxannotation的类,该类型采用目标类是否标注了某个注解进行过滤 |
assignable | com.rookie.bigdata.xxxservice | 所有继承或扩展xxxservice的类,该类型采用目标类是否继承或扩展了某个特定类进行过滤 |
aspectj | com.rookie.bigdata.*service+ | 所有类名以service结束的类及继承或扩展它们的类,该类采用aspectj表达式进行过滤 |
regex | com\.rookie\.bigdata\.annotation\.* | 所有com.rookie.bigdata.annotation类包下的类,该类型采用正则表达式根据目标类的类名进行过滤 |
custom | com.rookie.bigdata.xxxtypefilter | 采用xxxtypefile代码方式实现过滤规则。该类必须实现org.springframework.core.type.typefilter接口 |
<context:component-scan/>有一个容易忽视的use-default-filters属性,默认值为true;表示默认会对标注@component、@controller、@service及reposity的bean进行扫描,<context:component-scan/>先根据<exclude-filter>列出需要排除的黑名单,再通过<include-filter>列出需要包含的白名单。
自动装配bean
spring通过@authwired注解实现bean的依赖注入
如下:
@repository public class userdao { public userdao(){ system.out.println("实例化userdao"); } }
@service public class userservice { @autowired private userdao userdao; }
@autowired默认按照类型(bytype)匹配的方式在容器中查找匹配的bean,当有且仅有一个匹配的bean时,spring将其注入@autowired标注的变量中
@autowired还有一个required属性,默认情况下为true;表示必须找到匹配的bean,否则会报nosuchbeandefinitionexception异常。
@autowired(required =true)
private userdao userdao;
@qualifier注解
如果容器中有一个以上的匹配bean时,可以通过@qualifier注解限定bean的名称。如下:
@repository @qualifier(value = "userdao") public class userdao { public userdao(){ system.out.println("实例化userdao"); } }
@service public class userservice { @autowired(required =true) @qualifier(value = "userdao") private userdao userdao; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。