使用注解开发
在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:annotation-config/>
</beans>
1. bean
2.属性如何注入
//等价于<bean id="user" class="com.Sirius.pojo.User"/>
@Component
public class User {
//等价于<property name="name" value="张三"/>
@Value("张三")
public String name;
}
3.衍生的解释
@Component 有几个衍生注解,我们在web开发中,会按照mvc三层架构分层
- dao 【@Repository】
- service【@Service】
- controller 【@Controller】
这四个注解功能都是一样的,都是代表将某个类注册到Spring中,装配Bean
4.自动装配置
- @Autowired:自动装配,通过类型、名字。
如果Autowired不能为宜自动装配上属性,则需要通过@Qualifier(value=“xxx”) - @Nullable:字段标记了这个注解,说明这个字段可以为null。
- @Resource:自动装配通过名字、类型。
5.作用域
//等价于<bean id="user" class="com.Sirius.pojo.User"/>
@Component
@Scope("prototype") //作用域
public class User {
//等价于<property name="name" value="张三"/>
@Value("张三")
public String name;
}
6.小结
xml与注解:
- xml:更加万能,适用于任何场合,维护更加方便。
- 注解:不是自己的类使用不了,维护相对复杂
xml与注解最佳实践:
- xml用来管理bean。
- 注解只负责属性的注入。
- 在使用的过程中,只需要注意:必须让注解生效,就必须要开启注解的支持!
<!-- 指定要扫描的包,这个包下的注解就会生效 -->
<context:component-scan base-package="com.XXX"/>
<context:annotation-config/>