使用注解开发…

在Spring4之后,使用注解开发,必须要保证aop的包导入了
20201205134149
使用注解需要导入context约束,增加注解的支持!

1
2
3
4
5
6
7
8
9
10
11
12
<?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.属性如何注入

1
2
3
4
5
6
7
8
9
10
@Component
public class User {
public String name;

// 相当于<property name="name" value="marlowe2">
@Value("marlowe2")
public void setName(String name) {
this.name = name;
}
}

3.衍生的注解

@Component有几个衍生注解,我们再web开发中,会按照mvc三层架构分层!

  • dao【@Repository】
  • service【@Service】
  • controller【@Service】
    这四个注解的功能都是一样的,都是代表将某个类注册到Spring中,装配Bean

4.自动装配

1
2
3
4
- @Autowired:自动装配通过类型。名字
如果Autowired不能唯一自动装配上属性,则需要通过@Qualifier(value="xxx")
- @Nullable: 字段标记了这个注解,说明这个字段可以为null
- @Resource: 自动装配通过名字。类型

5.作用域

1
2
3
4
5
6
7
8
9
10
11
@Component
@Scope("prototype")
public class User {
public String name;

// 相当于<property name="name" value="marlowe2">
@Value("marlowe2")
public void setName(String name) {
this.name = name;
}
}

6.小结

xml与注解:

  • xml: 更加万能,适用于任何场合!维护简单方便
  • 注解: 不是自己的类使用不了,维护相对复杂!

xml与注解最佳实践:

  • xml用来管理bean
  • 注解只负责完成属性的注入
  • 我们在使用的过程中,只需要注意一个问题:必须让注解生效,就需要开启注解的支持
1
2
3
<!--指定要扫描的包,这个包下面的注解就会生效-->
<context:component-scan base-package="com.marlowe"/>
<context:annotation-config/>

评论