java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > @AutoWired与@Resource及@Qualifier注解

Spring中的@AutoWired与@Resource及@Qualifier注解详解

作者:MrMoving

这篇文章主要介绍了Spring中的@AutoWired与@Resource及@Qualifier注解详解,spring不但支持自己定义的@Autowired注解,所以Autowired与Spring是强相关性,只能在spring框架中使用,而后几个注解则不然,需要的朋友可以参考下

@AutoWired与@Resource及@Qualifier注解

spring不但支持自己定义的@Autowired注解(所以Autowired与Spring是强相关性,只能在spring框架中使用,而后几个注解则不然),还支持几个由JSR-250规范定义的注解,它们分别是@Resource、@PostConstruct以及@PreDestroy。

@PostConstruct

相当于init-method,使用在方法上,当Bean初始化时执行,执行顺序在@Autowire注解之后。

@PreDestroy

相当于destory-method,使用在方法上,当Bean销毁时执行。

@Autowired

@Autowired 注解可以用于 Setter 方法字段、构造函数。

也可用于普通方法,前提是方法必须有至少一个参数,很少用,此时会产生一个副作用,就是在容器初始化该 Bean 实例的时候就会调用该方法。

当然,前提是执行了自动装配,对于不满足装配条件的情况,该方法也不会被执行。

附:最近见到了不少将此注解标注在构造函数上的情况,如以下场景:
类A需要在初始化立刻执行某个操作method,但此操作需要必须在属性attribute初始化之后才能进行,方案有多种
1.实现InitializingBean接口,在afterPropertiesSet方法中执行method
2.实现ApplicationListener<ContextRefreshedEvent>接口,在onApplicationEvent方法中执行method
3.使用@postConstruct注解method方法,此注解标注的方法会在所有属性注入完成后,获取此bean前执行
4.属性attribute不使用自动装配,使用@Autowired注解构造函数,并注入attribute

@Autowired
 public A(Attribute attribute) {
	 this.attribute = attribute;
	 method();
 } 

@Autowired按byType自动注入,查找指定类型的Bean。找不到则抛出异常(可以给 @Autowired 标注增加一个 required=false 属性,以改变这个行为)。 如果找到多个bean,按以下方案进行:

  1. 选择其中带有Primary注解的bean,如果只有一个直接注入,如果有多个bean带有Primary注解则报错。
  2. 选择与@Qualifier注解的value值名称相同的Bean,如下,如果有名为zhangsan的User Bean,则注入,无则报错
	@Autowired 
 	@Qualifier("zhangsan")
 	public User user;

    // 注解在set方法上的例子
    @Autowired   
    public void setUserDao(@Qualifier("userDao") UserDao userDao) {   
        this.userDao = userDao;   
    }  

@Resource

其他扩展

常见定义Bean的注解:

@Controller

@Controller(“Bean的名称”)

定义控制层Bean,如Action

@Service

@Service(“Bean的名称”)

定义业务层Bean

@Repository

@Repository(“Bean的名称”)

定义DAO层Bean

@Component

它是一个通用泛化的注解,当某个组件不能通过业务进行归类时,可以使用这个注解进行标注。@Controller、@Repository、@Service是基于此注解的扩展,查看源码可以发现这三个注解上都标注了@Component 注解

@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Component
public @interface Controller {
    @AliasFor(
        annotation = Component.class
    )
    String value() default "";
}

以上几个注解效果是完全一样的,只是后三个用于方便标示该Bean的业务范围。

注:这几个注解都依赖于类的无参构造,如果未提供,则会在启动时报错

No default constructor found; nested exception is java.lang.NoSuchMethodException

到此这篇关于Spring中的@AutoWired与@Resource及@Qualifier注解详解的文章就介绍到这了,更多相关@AutoWired与@Resource及@Qualifier注解内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文