jdk1.5支持的注解,Spring2.5就支持注解了!
The introduction of annotation-based configuration raised the question of whether this approach is “better” than XML.
要使用注解须知:
1.导入约束:context约束
2.==配置注解的支持:<context:annotation-config/>[重要]开启注解支持
<?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>
@Autowired
直接在属性上使用即可!也可以在set方式上使用!
使用Autowired我们可以不用编写Set方法了,前提是你这个自动装配的属性在IOC(spring)容器中存在,且符合名字byname!
科普“
@Nullable 字段标记了这个注解,说明这个字段可以为null;
public @interface Autowired { boolean required() default true;
测试代码
public class person { // 如果显示定义了Autowired的required属性为fales,说明这个对象可以为null,否则不允许为空。 @Autowired(required = false) private Dog dog; @Autowired private Cat cat; private String name;
如果@Autowired自动装配的环境比较复杂,自动装配无法通过一个注解【@Autowired】完成的时候,我们可以使用@Qualifier(value="xxxx")去配置@Autowired的使用,指定一个唯一的bean对象注入!
public class person {
// 如果显示定义了Autowired的required属性为fales,说明这个对象可以为null,否则不允许为空。
@Autowired(required = false)
private Dog dog;
@Autowired
@Qualifier(value = "cat11")
private Cat cat;
private String name;
@Resource注解
public class person {
@Resource(name="cat2")
private Dog dog;
@Resource
private Cat cat;
小結:
@Resource和@Autowired的区别:
1.都是用来自动装配的,都可以放在属性字段上
2.@Autowired通过bytype的方式实现,而且必须要求这个对象存在!
3.@Resource默认通过byname的方式实现,如果找不到名字,则通过bytype实现!如果两个都找不到的情况下,就报错!
4.执行顺序不同:@Autowired通过bytype的方式实现