1. @Autowired 配置
首先介绍 @Autowired 注解的配置,通过该注解可以实现自动装配 Bean 的依赖。例如以下的 OrderService 类,通过 @Autowired 注解将其依赖的 OrderRepository 对象实例化并注入:
@Service
public class OrderService {
@Autowired
private OrderRepository orderRepository;
// ...
}
需要注意的是,在默认情况下,@Autowired 会按照类型进行依赖注入。如果容器中有多个同类型的 Bean,则会抛出异常。这时如果需要指定具体的 Bean,可以使用 @Qualifier 注解来实现。
@Service
public class OrderService {
@Autowired
@Qualifier("orderRepositoryImpl")
private OrderRepository orderRepository;
// ...
}
另外,还可以在构造器、Setter 方法以及其他自定义方法上使用 @Autowired 注解进行依赖注入。
@Service
public class OrderService {
private OrderRepository orderRepository;
@Autowired
public OrderService(OrderRepository orderRepository) {
this.orderRepository = orderRepository;
}
/**
* Setter injection.
*/
@Autowired
public void setOrderRepository(OrderRepository orderRepository) {
this.orderRepository = orderRepository;
}
/**
* Custom method injection.
*/
@Autowired
public void injectOrderRepository(OrderRepository orderRepository) {
this.orderRepository = orderRepository;
}
// ...
}
2. @Resource 配置
接下来介绍 @Resource 注解的配置,同样可以实现自动装配 Bean 的依赖。相比于 @Autowired,它使用的是名称来进行依赖注入。
例如以下的 OrderService 类,通过 @Resource 注解将其依赖的 OrderRepository 对象实例化并注入:
@Service
public class OrderService {
@Resource(name = "orderRepositoryImpl")
private OrderRepository orderRepository;
// ...
}
需要注意的是,默认情况下会根据属性名与 Bean 名称进行匹配。如果需要指定名称,则可以使用 name 属性来设置。
同时, @Resource 还支持 type 属性,可以按照类型来进行依赖注入。例如以下代码:
@Service
public class OrderService {
@Resource(type = OrderRepository.class)
private OrderRepository orderRepository;
// ...
}
3. 区别比较
综上所述,两者的区别主要在于依赖注入的方式不同。
对于 @Autowired,它按照类型进行依赖注入,如果有多个同类型的 Bean 则需要使用 @Qualifier 来区分。而 @Resource 则按照名称或类型进行依赖注入,通过 name 或 type 属性进行配置。
在使用上,两者都可以实现自动装配 Bean 的依赖关系,但使用场景略有不同。一般情况下,如果我们只需要按照类型注入,那么优先使用 @Autowired。如果需要按照名称或类型注入,则优先使用 @Resource。
需要注意的是,在 Spring 5.1 及以上版本,@Autowired 和 @Qualifier 存在一个新的特性——默认注解值(Default Annotation Values)。即当按照类型进行注入时,可以通过 @Qualifier 注解的默认值来指定具体的 Bean 名称。这样 @Resource 在一定程度上的优势就被削弱了。
@Service
public class OrderService {
@Autowired
@Qualifier("orderRepositoryImpl")
private OrderRepository orderRepository;
// ...
}
因此,在使用时应该根据具体情况选择合适的注解来实现依赖注入。