Spring@Autowired注解与自动装配

1   配置文件的方法

 

我们编写spring 框架的代码时候。一直遵循是这样一个规则:所有在spring中注入的bean 都建议定义成私有的域变量。并且要配套写上 get 和 set方法。

 清单1 Office.java

package exampleBean;

public class Office {
	private String officeNo;

	public void setOfficeNo(String officeNo) {
		this.officeNo = officeNo;
	}

	public String getOfficeNo() {
		return officeNo;
	}

	public String toString() {
		return "String:" + officeNo;
	}
}

清单2:Car.java

package exampleBean;

public class Car {
	private String brand, price;

	public void setBrand(String brand) {
		this.brand = brand;
	}

	public String getBrand() {
		return brand;
	}

	public void setPrice(String price) {
		this.price = price;
	}

	public String getPrice() {
		return price;
	}

}


Boss 拥有 Office 和 Car 类型的两个属性:   
  
  
清单 3. Boss.java

package exampleBean;

import org.springframework.beans.factory.annotation.Autowired;

public class Boss {

	private Car car;
	private Office office;

	public void setCar(Car car) {
		this.car = car;
	}

	public Car getCar() {
		return car;
	}

	public void setOffice(Office office) {
		this.office = office;
	}

	public Office getoffice() {
		return office;
	}

	@Override
	public String toString() {
		return "car:" + car + "/n" + "office:" + office;
	}
}

System.out.println必须实现toString方法
  
我们在 Spring 容器中将 Office 和 Car 声明为 Bean,并注入到 Boss Bean 中:下面是使用传统 XML 完成这个工作的配置文件 beans.xml:   
  
  
清单 4. beans.xml 将以上三个类配置成 Bean   

<?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:c="http://www.springframework.org/schema/c"
	xsi:schemaLocation="http://www.springframework.org/schema/beans
      http://www.springframework.org/schema/beans/spring-beans.xsd">
	<!-- 该 BeanPostProcessor 将自动对标注 @Autowired 的 Bean 进行注入 -->
	<bean
		class="org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor" />

	<bean id="boss" class="exampleBean.Boss">
		<property name="car" ref="car" />
		<property name="office" ref="office" />
	</bean>
	<bean id="office" class="exampleBean.Office">
		<property name="officeNo" value="002" />
	</bean>
	<bean id="car" class="exampleBean.Car" scope="singleton">
		<property name="brand" value="红旗 CA72" />
		<property name="price" value="2000" />
	</bean>
</beans>
当我们运行以下代码时,控制台将正确打出 boss 的信息:   
  
  
清单 5. 测试类:AnnoIoCTest.java   

import org.springframework.context.ApplicationContext;   
import org.springframework.context.support.ClassPathXmlApplicationContext;   
public class AnnoIoCTest {   
  
    public static void main(String[] args) {   
        String[] locations = {"beans.xml"};   
        ApplicationContext ctx =    
            new ClassPathXmlApplicationContext(locations);   
        Boss boss = (Boss) ctx.getBean("boss");   
        System.out.println(boss);   
    }   
}   
    

这说明 Spring 容器已经正确完成了 Bean 创建和装配的工作。  


2   @Autowired 

 

Spring 2.5 引入了 @Autowired 注释,它可以对类成员变量、方法及构造函数进行标注,完成自动装配的工作。 通过 @Autowired的使用来消除 set ,get方法。

 

 

要实现我们要精简程序的目的。需要这样来处理: 

* 在applicationContext.xml中加入: 
  

<!-- 该 BeanPostProcessor 将自动对标注 @Autowired 的 Bean 进行注入 -->
	<bean
		class="org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor" />

Spring 通过一个 BeanPostProcessor 对 @Autowired 进行解析,所以要让 @Autowired 起作用必须事先在 Spring 容器中声明 AutowiredAnnotationBeanPostProcessor Bean。   


* 修改在原来注入spirng容器中的bean的方法。 
     在域变量上加上标签@Autowired,并且去掉 相应的get 和set方法

 

清单 6. 使用 @Autowired 注释的 Boss.java   

package exampleBean;
import org.springframework.beans.factory.annotation.Autowired;
public class Boss {
	@Autowired
	private Car car;
	@Autowired
	private Office office;
	@Override
	public String toString() {
		return "car:" + car + "/n" + "office:" + office;
	}
}


* 在applicatonContext.xml中 把原来 引用的<porpery >标签也去掉。

 

<?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:c="http://www.springframework.org/schema/c"
	xsi:schemaLocation="http://www.springframework.org/schema/beans
      http://www.springframework.org/schema/beans/spring-beans.xsd">
	<!-- 该 BeanPostProcessor 将自动对标注 @Autowired 的 Bean 进行注入 -->
	<bean
		class="org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor" />

	<bean id="boss" class="exampleBean.Boss">
	</bean>
	<bean id="office" class="exampleBean.Office">
		<property name="officeNo" value="002" />
	</bean>
	<bean id="car" class="exampleBean.Car" scope="singleton">
		<property name="brand" value="红旗 CA72" />
		<property name="price" value="2000" />
	</bean>
</beans>

 这样,当 Spring 容器启动时,AutowiredAnnotationBeanPostProcessor 将扫描 Spring 容器中所有 Bean,当发现 Bean 中拥有 @Autowired 注释时就找到和其匹配(默认按类型匹配)的 Bean,并注入到对应的地方中去。   
  
按照上面的配置,Spring 将直接采用 Java 反射机制对 Boss 中的 car 和 office 这两个私有成员变量进行自动注入。所以对成员变量使用 @Autowired 后,您大可将它们的 setter 方法(setCar() 和 setOffice())从 Boss 中删除。   
  
当然,您也可以通过 @Autowired 对方法或构造函数进行标注,如果构造函数有两个入参,分别是 bean1 和 bean2,@Autowired 将分别寻找和它们类型匹配的 Bean,将它们作为 CountryService (Bean1 bean1 ,Bean2 bean2) 的入参来创建 CountryService Bean。来看下面的代码:  对方法

 

package exampleBean;

import org.springframework.beans.factory.annotation.Autowired;

public class Boss {

	private Car car;
	private Office office;

	@Autowired
	public void setCar(Car car) {
		this.car = car;
	}

	@Autowired
	public void setOffice(Office office) {
		this.office = office;
	}
	
	@Override
	public String toString() {
		return "car:" + car + "/n" + "office:" + office;
	}
}

 

这时,@Autowired 将查找被标注的方法的入参类型的 Bean,并调用方法自动注入这些 Bean。而下面的使用方法则对构造函数进行标注:   

package exampleBean;

import org.springframework.beans.factory.annotation.Autowired;

public class Boss {

	private Car car;
	private Office office;

	@Autowired
	public Boss(Car car, Office office) {
		this.car = car;
		this.office = office;
	}

	@Override
	public String toString() {
		return "car:" + car + "/n" + "office:" + office;
	}
}


由于 Boss() 构造函数有两个入参,分别是 car 和 office,@Autowired 将分别寻找和它们类型匹配的 Bean,将它们作为 Boss(Car car ,Office office) 的入参来创建 Boss Bean。  



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值