在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
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:component-scan base-package="com.sunfl.pojo"/>
<context:annotation-config/>
</beans>
- bean
属性如何注入
//等价于 <bean id="user" class="com.sunfl.pojo.User"/> @Component public class User { public String name; //相当于<property name="name" value="向日葵"> @Value("向日葵") public void setName(String name) { this.name = name; } }
衍生的注解
@Component有几个衍生注解,我们在web开发中,会按照mvc三层架构分层- dao 【@Repository】
- service 【@Service】
- controller 【@Controller】
这四个注解功能都是一样的,都是代表将某个类注册到Spring容器中,装配Bean
自动装配置
- @Autowired:自动装配通过类型、名字
- @Nullable:字段标记了这个注解,说明这个字段可以为null
- @Resource:自动装配通过类型、名字
作用域
@Component @Scope("prototype") public class User { }
小结
xml与注解对比:- xml更加万能,适用于任何场合!维护简单方便
- 注解 不是自己类使用不了,维护相对复杂
最佳实践:
- xml用来管理bean
- 注解只负责完成属性的注入
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。