基于注解的SpringIoc配置

2.4 基于注解的Ioc配置

xml与注解的对应

mark

使用注解开发时,bean.xml中的约束与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
        http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd">

    <context:annotation-config/>
</beans>

与XML配置功能相对应的注解

  • 用于创建对象的
		@Component:
/**	
			作用:用于把当前类对象存入spring容器中
			属性:
				value:用于指定bean的id。当我们不写时
					   它的默认值是当前类名,且首字母改
                       小写
*/		
	// 这里另外介绍3个与Component作用和属性一摸一样的注解
		@Controller:一般用在表现层
		@Service:一般用在业务层
		@Repository:一般用在持久层
		以上三个注解他们的作用和属性与Component是一摸一样。
		他们三个是spring框架为我们提供明确的三层使用的注解
		,使我们的三层对象更加清晰

对应的xml配置(忽略约束)

<!-- 告知spring在创建容器时要扫描的包,配置所需要的标签
	 不是在beans的约束中,而是一个名称为context名称空
	 间和约束中 -->
	<context:component-scan base-package="com"></context:component-scan>
  • 用于注入数据的
		@Autowired:
/**	
			作用:自动按照类型注入。只要容器中有唯一的一个bean对象类型和
				 要注入的变量类型匹配,就可以注入成功。
				 如果Ioc容器中没有任何bean的类型和要注入的变量类型匹配,
				 则报错。
		    出现位置:(可注解位置)
				 可以是变量上,也可以是方法上
			细节:
				 在使用注解注入时,set方法就不是必须的了。
*/		
		@Qualifier:
		(基于@Autowired注解)
/**	
			作用:在按照类中注入的基础之上再按照名称注入。它在给类成员注入
				 注入时不能单独使用。但是在给方法参数注入时可以
		    出现位置:
		    	 基于@Autowired注解	
			属性:
				 value:用于指定注入bean的id
			单独使用的特殊情况:
				 当容器中含有两个或以上相同的类且bean的id名不同时,可以
				 在方法中配置@Qualifier注解,如下图
*/	

mark

		@Resource
/**	
			作用:直接按照bean的id注入。它可以独立使用
			属性:
				 name:用于指定bean的id
*/	

以上三个注入都只能注入其他bean类型的数据,而基本类型和String类型无法使用上述注解实现
另外,集合类型的注入只能通过XML来实现,于是下面的要讲的Value注解可以实现基本类型和
String类型数据的注入

		@Value
/**	
			作用:用于注入基本类型和String类型的数据
			属性:
				 value:用于指定数据的值。它可以使用
						spring中的SpEL(spring的el表达式)
						SpEL的写法:${表达式}
*/	
  • 用于改变作用范围的
		@Scope
/**	
			作用:用于指定bean的作用范围
			属性:
				 value:指定范围的取值。(默认单例)
				 常用取值:singleton、prototype
*/	
  • 和生命周期相关的(了解即可)
		@PreDestory
			// 作用:用于指定销毁方法
		@PostConstruct
			// 作用:用于指定初始化方法
取代xml配置文件的注解类

如果不想使用xml配置文件,spring也可以允许你创建一个配置类来配置Ioc容器

		@Configuration
			/** 作用:指定当前类是一个配置类
			 细节:当配置类作为AnnotationConfigApplicationContext对象
					创建的参数时,该注解可以不写
			*/
		@ComponentScan
			/** 作用:用于通过注解指定spring在创建容器时要扫描的包
			    属性:
					 value:它和basePackages的作用是一样的,都是用于
							指定创建容器时要扫描的包,等同于xml中配置了
<context:component-scan base-package=""></context:component-scan>
			*/
		@Import
			/** 作用:用于导入其他的配置类
				属性:
					 value:用于指定其他配置类的字节码文件
					 	 	当我们使用Import的注解之后,有Import注解的
							类可视为父配置类,而导入的都是子配置类
			*/
		@PropertySource
			/** 作用:用于指定properties文件的位置
				属性:
					 value:指定文件的名称和路径。
						    关键字:classpath,表示类路径下
			*/

将类对象加入Ioc容器的注解

		@Bean
			/** 作用:用于把当前方法的返回值作为bean对象存入spring的ioc容器中
			    属性:
					 name:用于指定bean的id。当不写时,默认值时当前方法的名称
				细节:
					 当我们使用注解配置方法时,如果方法有参数,spring框架会去
					 容器中查找有没有可用的bean对象。
					 查找的方式和Autowired注解的作用是一样的
			*/

创建Ioc容器对象时,我们不能再使用之前的
ApplicationContext ac = new ClassPathXmlApplicationContext(“beam.xml”);
新的创建对象的方式见下方代码块

// 获取容器
ApplicationContext ac = new AnnotationConfigApplicationContext(SpringConfiguration.class);

小贴士:
通过实际操作我们可以发现,注解Ioc配置并没有比配置xml文件更简单
因此我们在实际开发中,如果不是企业硬性要求,我们使用注解或xml的
原则是怎么简单怎么来
当我们需要导入容器的类在jar包中时
使用xml配置显然更简单
当我们自己写的类要导入容器时
使用注解显然更简单

Spring整合Junit

markmark

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值