在Spring4之后,要使用注解开发,必须要保证aop的包导入了
-
使用注解需要导入context约束,增加注解的支持
<?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:component-scan base-package="com.lrm"/> <!--开启注解的支持--> <context:annotation-config/> </beans>
-
注解说明
-
@Autowired:自动装配通过类型、名字
如果Autowired不能唯一自动装配上属性,则需要通过@Qualifier(value=“xxx”)
-
@Nullable:字段标记了这个注解,说明这个字段可以为null
-
@Resource:自动装配通过名字、类型
-
@Component:组件;放在类上,说明这个类被Spring管理了,这个就是bean
-
1. bean
//等价于<bean id = "user" class = "com.lrm.pojo.User"/>
@Component
public class User {...}
2. 属性如何注入
//等价于<bean id = "user" class = "com.lrm.pojo.User"/>
@Component
public class User {
public String name;
//相当于<property name = "name" value = "123"/>
@Value("123")
public void setName(String name){
this.name = name;
}
}
3. 衍生的注解
@Component【pojo包】有几个衍生注解,在web开发中,会按照mvc三层架构分层
-
dao【@Repository】
-
service【@Service】
-
controller【@Controller】
这四个注解功能是一样的,都是代表将某个类注册到Spring中,装配bean
4. 自动装配
-
@Autowired:自动装配通过类型、名字
如果Autowired不能唯一自动装配上属性,则需要通过@Qualifier(value=“xxx”)
-
@Nullable:字段标记了这个注解,说明这个字段可以为null
-
@Resource:自动装配通过名字、类型
5. 作用域
在类上加上@Scope注解
-
@Scope(“singleton”):使用单例模式(默认)
-
@Scope(“prototype”):原型模式(每次从容器中get的时候,都会产生一个新的对象)
6. 小结
xml与注解:
- xml更加万能,适用于任何场景,维护更加简单方便
- 注解 不是自己的类使用不了,维护相对复杂
xml与注解的最佳实践:
- xml用来管理bean
- 注解只负责完成属性的注入