概述
在Spring框架中,@Primary
注解用于解决依赖注入时的选择冲突。当存在多个同类型的Bean可供注入时,Spring默认会抛出异常。使用@Primary
注解,可以指示Spring在遇到多个候选Bean时优先选择标记了该注解的Bean。
应用场景
- 多个实现:当一个接口有多个实现类时,如果想要默认注入某一个实现,可以使用
@Primary
。 - 不同配置环境:在多种配置环境下,有时需要优先使用某个特定的Bean,比如在测试环境和生产环境中可能会有不同的实现。
- 避免显式指定:如果不希望在每次注入时都显式指定Bean的名称,可以使用
@Primary
来简化代码。
示例代码
假设我们有一个GreetingService
接口和两个实现类EnglishGreetingService
和SpanishGreetingService
。
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
public interface GreetingService {
String greet();
}
@Configuration
class GreetingConfig {
@Bean
@Primary
public GreetingService englishGreetingService() {
return new EnglishGreetingService();
}
@Bean
public GreetingService spanishGreetingService() {
return new SpanishGreetingService();
}
}
class EnglishGreetingService implements GreetingService {
@Override
public String greet() {
return "Hello!";
}
}
class SpanishGreetingService implements GreetingService {
@Override
public String greet() {
return "¡Hola!";
}
}
在这个示例中,我们定义了两个GreetingService
的实现:EnglishGreetingService
和SpanishGreetingService
。我们在englishGreetingService
方法上使用了@Primary
注解,因此在注入GreetingService
时,默认会注入EnglishGreetingService
。
使用示例
在某个需要注入GreetingService
的地方:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
@Component
public class GreetingController {
private final GreetingService greetingService;
@Autowired
public GreetingController(GreetingService greetingService) {
this.greetingService = greetingService;
}
public void sayGreeting() {
System.out.println(greetingService.greet()); // 输出 "Hello!"
}
}
小结
@Primary
注解用于解决多个Bean冲突,指定优先注入的Bean。- 适合在有多个实现类时使用,避免在每次注入时都需要显式指定Bean。
- 配置简单,可以有效管理复杂的依赖关系。