Spring--高级装配

一、@Profile

标注当前运行环境(开发环境、测试环境、线上环境等)的注解。

1、在需要配置环境的类上添加注解

@Component

@Profile("prod")

public class Prod{

// ToDo

}

 

@Component

@Profile("Dev")

public class Dev{

// ToDo

}

 

2、在使用该类实例的类上添加注解,激活相应Profile并注册Bean到Spring容器中

@Component

@ActiveProfiles("prod") // 注册Prod类的Bean到Spring容器中

public class Test{

// ToDo

}

 

二、条件化Bean

当我们需要Bean在满足一定条件下才创建,引入@Conditional注解。

@Bean

@Conditional(TestCondition.class)

public TestBean testBean(){

return new TestBean();

}

其中TestCondition实现了Condition接口,如果matches()方法返回ture,就会创建带有@Conditional注解的Bean,否则不创建。

 

三、标识首选Bean

前面提到一个bean有多个实现时,会产生歧义,spring不知道使用哪一个bean,那么这时我们就需要使用@Primary注解标注当前需要使用的bean。

@Component

@Primary

public class ImplementBean implements InterfaceBean{

// ToDo

}

或者java显示配置

@Bean

@Primary

public InterfaceBean interfaceBean(){

return new ImplementBean();

}

或者XML配置

<bean id="implementBean" class="com.xxx.ImplementBean" primary="true">

 

四、默认限定符标识bean

根据第三点来推敲,问题来了,如果一个bean在被多个bean实现后,不同的地方都需要使用的情况下,怎么办? 这时候我们就需要使用限定符来标识bean了,而@Qualifier注解是使用限定符的主要方式。

@Autowired

@Qualifier("implementBeanName") // 也就是创建bean的默认ID,类名第一字母小写

public void setInterfaceBean(InterfaceBean interfaceBean){

// ToDo

}

以上是使用相应bean默认ID作为限定符,但问题又来了,如果我们对代码进行重构的时候修改了类名,原来默认的限定符就失效了,真是套路一环又一环啊。

 

五、不怕,还有自定义限定符

@Component

@Qualifier("customName")

public class ImplementBean implements InterfaceBean{

// ToDo

}

 

@Autowired

@Qualifier("customName") // 也就是创建bean的默认ID,类名第一字母小写

public void setInterfaceBean(InterfaceBean interfaceBean){

// ToDo

}

不过,最好不要随便取名字,搞得自己都分不清东南西北就不妙了,要根据具体的使用场景和功能来命名一个合适的限定符名称。另外,还可以自己定义限定符注解哈,再此不做详细描述。

 

六、Bean作用域

默认情况下,Spring应用上下文中的bean是以单例的形式存在创建的,不管bean被注入多少次,始终都是同一个bean实例,在面对可变并需要保存不同状态的时候,单例bean就力不从心了。Bean的作用域刚好可以解决这个问题,好巧合的样子。

Spring作用域:

单例(Singleton):在应用范围内,有且只有一个bean实例;// 默认作用域

原型(Prototype):在应用范围内,每次注入都会创建一个新的bean实例;

会话(Session):Web应用中,为每一个会话创建一个bean;

请求(Rquest):Web应用中,为每一个请求创建一个bean。

 

七、运行时值注入

我陡然发现,如果依赖注入不是把一个bean注入另一个bean的属性或构造函数中,而是将一个值动态注入到bean的属性或构造函数中,我们要采取什么措施呢?那就是运行时值注入。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring-IOC是Spring框架的核心部分之一,它是一种设计模式,全称为Inversion of Control(控制反转)。它通过将对象的创建、依赖关系的管理和对象的生命周期交给Spring容器来实现,从而降低了组件之间的耦合度,提高了代码的可重用性和可维护性。Spring-IOC的实现主要依靠Spring容器,Spring容器是Spring框架的核心,它负责创建、管理和装配Bean对象,其中Bean是Spring框架中最基本的组件。 Spring-IOC的实现主要有两种方式:BeanFactory和ApplicationContext。其中,BeanFactory是Spring-IOC的基本实现,而ApplicationContext是BeanFactory的子接口,提供了更多高级特性。ApplicationContext是Spring框架中最常用的IOC容器,它除了提供BeanFactory的所有功能外,还提供了更多的企业级特性,例如AOP、事务管理、国际化、事件传播等。 下面是一个简单的Spring-IOC的例子,假设我们有一个UserService接口和一个UserServiceImpl实现类,我们可以通过Spring-IOC容器来创建和管理UserServiceImpl对象: 1.定义UserService接口和UserServiceImpl实现类 ```java public interface UserService { void addUser(User user); } @Service public class UserServiceImpl implements UserService { @Override public void addUser(User user) { // 添加用户的具体实现 } } ``` 2.在Spring配置文件中配置UserService实例 ```xml <bean id="userService" class="com.example.service.UserServiceImpl"/> ``` 3.在代码中获取UserService实例并使用 ```java ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml"); UserService userService = context.getBean("userService", UserService.class); User user = new User(); userService.addUser(user); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值