@Autowired 在Spring2.5引入,可以对
1.成员变量
2.方法和
3. 构造函数 进行标注来完成自动装配的工作。
无需再通过传统的在bean的xml文件中进行bean的注入配置。而是使用注解,系统自动为你注入,即隐式配置。
首先要知道:@Autowired是根据类型进行标注的,如需要按照名称进行装配,则需要配合@Qualifier使用
进行指定包扫描的component
使用示例
创建一个Spring的配置文件
<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-4.0.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
">
<context:component-scan base-package="AutowiredTest"/>
<bean id="cdPlayer" class="AutowiredTest.CDPlayer"/>
</beans
写一个测试用的接口,这里命名为光盘(CompactDisc)
public interface CompactDisc {
void play();
}
利用注解@Component声明一个组件类。
具体实现:
@Component
public class SgtPeppers implements CompactDisc{
@Override
public void play() {
System.out.println("SgtPeppers playing....");
}
}
或者在构造函数上
public class CDPlayer {
CompactDisc cd;
//对构造函数进行标注
@Autowired
public CDPlayer(CompactDisc cd){
this.cd = cd;
}
public void say(){
cd.play();
}
}
注意:如果构造函数有两个入参,分别是 bean1 和 bean2,@Autowired 将分别寻找和它们类型匹配的 Bean
编写一个测试类,作为验证是否自动为我们注入了 CompactDisc。
public class Test {
public static void main(String[] args) {
ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("AutowiredBean.xml");
CDPlayer player = (CDPlayer) context.getBean("cdPlayer");
player.say();
}
}
结果: SgtPeppers playing….
运行,验证成功了,系统为我们自动注入了SgtPeppers这个组件类。
由于针对接口编程,因此很有可能多个类实现了同一个接口,这时Spring如果扫描到多个匹配对象,导致Spring不知道选择哪个好,那Spring不客气的就报错了。。。为了解决此问题,继续往下看。
装配冲突问题
如果还有个OtherPeppers类也实现CompactDisc这个接口,同时也注解为组件类,那会发生什么?
运行发现 报错了:
org.springframework.beans.factory.BeanCreationException:
Error creating bean with name 'cdPlayer':
Injection of autowired dependencies failed;
nested exception is org.springframework.beans.factory.BeanCreationException:
Could not autowire method:
public void AutowiredTest.CDPlayer.setCompactDisc(AutowiredTest.CompactDisc);
nested exception is org.springframework.beans.factory.NoUniqueBeanDefinitionException:
No qualifying bean of type [AutowiredTest.CompactDisc] is defined:
expected single matching bean but found 2: otherPeppers,sgtPeppers
上面的问题发生了歧义性问题,解决其中的办法有多种。
1、设置首选的Component,通过@Primary进行标注(如果多处都标注,依然出现歧义性问题);
2、限定自动装配的bean,在自动装配注解出添加注解@Qualifier(“name”),其中name为bean的ID(默认bean ID为类名首字母小写);如果重命名了组件类,那么自动装配将会失败。
3、通过自定义的限定符,其实就是在组件类与自动装配处,同时注解Qualifier(“name”),name为自定义且两出相同。
4、通过使用自定义的限定符注解,例如我用使用@Cold来标注组件类和自动装配两处。那么@Cold怎么自定义呢?我们需要自定义下该注解。
@Target({ElementType.CONSTRUCTOR,ElementType.FIELD,ElementType.METHOD,ElementType,TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Qualifier
public @interface Creamy{}
拓展篇
1、@Autowired与@Resource都可以用来装配bean. 都可以写在字段上,或写在setter方法上。
2、@Autowired默认按类型装配(这个注解是属业spring的),默认情况下必须要求依赖对象必须存在,如果要允许null 值,可以设置它的required属性为false,如:@Autowired(required=false) ,如果我们想使用名称装配可以结合@Qualifier注解进行使用,如下:
@Autowired() @Qualifier("baseDao")
private BaseDao baseDao;
3、@Resource(这个注解属于J2EE的),默认安照名称进行装配,名称可以通过name属性进行指定,
如果没有指定name属性,当注解写在字段上时,默认取字段名进行按照名称查找,如果注解写在setter方法上默认取属性名进行装配。 当找不到与名称匹配的bean时才按照类型进行装配。但是需要注意的是,如果name属性一旦指定,就只会按照名称进行装配,如下所示。
@Resource(name="baseDao")
private BaseDao baseDao;
用 @Resource注解在字段上,且这个注解是属于J2EE的,减少了与spring的耦合。
相关推荐
Spring 依赖注入:@Autowired,@...总结来说,@Autowired、@Resource 和@Inject 是三种不同的依赖注入方式,每种方式都有其特点和应用场景。理解这些依赖注入方式的区别和实现原理对于开发 Spring 应用程序非常重要。
针对@Autowired报错的情况,我们可以采取以下几种方式来解决: ##### 解决方案1:关闭报警机制 关闭IDEA对于@Autowired的报警机制是最直接的方法之一。通过调整IDEA的设置,我们可以让IDEA不再对@Autowired报错。...
在Spring Boot应用中,`@Autowired`注解用于自动装配依赖的bean,是Spring框架提供的一种依赖注入方式。然而,当出现`@Autowired`无法注入的情况时,这通常意味着Spring容器无法正确地扫描并管理你的组件。在描述中...
@Autowired 是 Spring 提供的一种自动装配机制,它可以根据类型自动寻找并注入相应的 Bean。不推荐直接使用,因为它的行为可能不如 @Resource 明确。在使用 @Autowired 时,需要在配置文件中添加 `...
以上三种方式各有优缺点。`ApplicationContext`提供了最大的灵活性,但代码更显式;`@Autowired`和`@Resource`则提供了更多的自动化,降低了代码的冗余,但可能隐藏了依赖关系。在实际开发中,根据项目需求和团队...
本篇主要介绍Spring中的三种注入方式,包括构造器注入、设值注入和接口注入。 首先,我们来看构造器注入。构造器注入是在创建对象时,通过构造器传递依赖对象。这种方式强制了对象在创建时就必须提供所有必要的依赖...
在Spring框架中,自动装配(Auto-Wiring)是一种简化依赖注入(Dependency Injection,DI)配置的方式,它允许Spring容器自动管理Bean之间的依赖关系。本文将深入探讨如何通过注解(Annotation)和`@Resource`来实现...
#### 一、传统方式与注解方式对比 在Spring框架中,依赖注入(DI)是一种核心的设计模式,用于促进松耦合的系统设计,使得组件之间的依赖关系可以在运行时动态地建立,而不是在编译时硬编码。在Spring早期版本中,...
本知识点将深入探讨Spring框架如何通过注解方式实现依赖注入,以帮助开发者更好地理解和应用这一特性。 一、依赖注入的概念 依赖注入是一种设计模式,其核心思想是将对象之间的依赖关系从代码中分离出来,由外部...
在Spring框架中,注解注入是一种非常常用且强大的依赖注入(Dependency Injection,简称DI)方式。依赖注入是Spring的核心特性之一,它允许开发者在不直接创建对象的情况下,将依赖关系从对象代码中分离出来,提高了...
本教程将详细阐述三种不同的方式,将Spring项目启动时加载的类集成到静态服务类中。 1. **使用`ApplicationContextAware`接口** `ApplicationContextAware`是Spring提供的一个接口,它允许我们在类中注入...
以上就是Spring和Hibernate结合注解的实现方式,这种模式极大地简化了配置,使得代码更加模块化,易于维护。在实际项目中,开发者可以根据需求选择合适的注解,灵活地进行数据访问层的设计和实现。
自动装配是Spring IoC(控制反转)的一种实现方式,IoC意味着容器负责创建对象并管理它们的生命周期,包括对象之间的依赖关系。自动装配通过分析bean定义来确定哪些bean应该被注入到其他bean中,从而减少XML配置文件...
Annotation是一种元数据,允许开发者在代码中嵌入额外的信息,Spring则能够读取这些信息来实现其功能,如自动装配Bean、定义切点和通知等。 #### 二、Annotation在Spring中的应用 ##### 1. `@Autowired`与依赖注入...
Spring 3.x 框架引入了依赖注入的注解,改变了传统的 XML 配置方式,提供了一种更加灵活和方便的依赖配置方式。下面对 Spring 3.x 的注解应用进行详细的介绍。 一、属性装配 在 Spring 3.x 中,提供了两种用于...
在Java编程中,注解(Annotation)是一种元数据,它提供了在代码中插入信息的方式,这些信息可以被编译器或运行时环境读取。Spring框架广泛使用了注解来简化配置,例如`@Autowired`、`@Component`、`@Configuration`...
与`@Autowired`类似,`@Resource`也可以实现依赖注入,但它默认采用按名称(byName)的方式进行注入。 `@Resource`具有`name`和`type`两个属性,通过设置这些属性可以指定注入方式: - **按名称注入**: ```java ...
本篇主要介绍Spring中的三种注入方式,包括构造器注入、设值注入和接口注入。 **一、构造器注入** 构造器注入是通过构造函数来传递依赖对象的一种方式。当类有多个构造函数时,Spring会使用带有最多参数的构造函数...
Spring框架支持多种注解,如`@Autowired`、`@Qualifier`、`@Resource`等,用于实现依赖注入。 1. `@Autowired`注解:这是Spring中最常用的注解,用于自动装配bean的依赖。当Spring容器遇到一个带有`@Autowired`注解...
本篇将详细探讨"3Spring使用annotation方式autowire"这一主题,包括注解驱动的自动装配(Autowiring)以及相关的源码分析。 ### 一、注解驱动的自动装配 自动装配是Spring框架的一个核心特性,它允许框架自动管理...