ObjectProvider的理论与实战

ObjectProvider的理论与实战

简介

ObjectProvider是一个接口,用于在Spring框架中获取对象实例。它提供了一种延迟加载对象的机制,可以在需要时动态地获取对象。

ObjectProvider的一个重要特性是它支持泛型。通过使用泛型,我们可以指定要获取的Bean的类型,这样可以避免类型转换的麻烦。例如,我们可以使用ObjectProvider来获取类型为MyBean的Bean实例。

在Spring中,我们可以通过依赖注入(Dependency Injection)来获取对象实例。通常情况下,我们使用@Autowired注解或构造函数注入来获取对象。但是有时候,我们希望在运行时动态地获取对象,或者需要根据条件来选择不同的对象实例。这时,ObjectProvider就能发挥作用。

使用ObjectProvider的步骤如下:

  1. 在类中声明一个ObjectProvider类型的成员变量,并使用@Autowired注解进行注入。例如:
@Autowired
private ObjectProvider<MessageService> messageServiceProvider;

  1. 在需要获取对象的地方,调用getObject()方法来获取对象实例。例如:
MessageService messageService = messageServiceProvider.getObject();
  1. 可以使用getIfAvailable()方法来获取对象实例,如果对象不存在,则返回null。例如:
 MessageService messageService = messageServiceProvider.getIfAvailable();
  1. 可以使用getIfUnique()方法来获取唯一的对象实例,如果存在多个对象,则抛出异常。例如:
MessageService messageService = messageServiceProvider.getIfUnique()

通过使用ObjectProvider,我们可以实现动态获取对象实例的能力。它可以延迟加载对象,只有在需要时才进行实例化,从而提高性能和资源利用率。同时,它还可以根据条件或配置来选择不同的对象实例,提供了灵活的对象管理机制。

需要注意的是,ObjectProvider是在Spring 4.3版本引入的,因此需要确保使用的Spring版本符合要求。

总结起来,ObjectProvider是一个用于获取对象实例的接口,在Spring框架中可以通过依赖注入来使用它。它提供了延迟加载和动态获取对象的能力,可以提高代码的灵活性和可维护性。

实战验证

@RestController
public class MsgController {


    private final ObjectProvider<MessageService> messageServiceProvider;

    @Autowired
    public MsgController(ObjectProvider<MessageService> messageServiceProvider) {
        this.messageServiceProvider = messageServiceProvider;
    }

    @GetMapping("/send")
    public void send(String message) {
        MessageService messageService = messageServiceProvider.getIfAvailable();
        if (messageService != null) {
            messageService.sendMessage(message);
        }
    }
}



public interface MessageService {
    void sendMessage(String message);
}

@Service
@Primary
public class EmailService implements MessageService {
    @Override
    public void sendMessage(String message) {
        System.out.println("Sending email: " + message);
    }
}

@Service
public class SmsService implements MessageService {
    @Override
    public void sendMessage(String message) {
        System.out.println("Sending SMS: " + message);
    }
}

在上面的代码中,我们通过构造函数注入了一个ObjectProvider实例。然后,在send()方法中,我们使用getIfAvailable()方法来获取MessageService的实例。如果实例存在,就调用sendMessage()方法发送消息。

这样,我们就可以根据具体的配置来决定使用哪种消息发送方式。我们可以通过@Primary注解或者@Qualifier注解来指定要使用的实现类。

@Lazy

@Lazy用于延迟加载Bean。当一个Bean被标记为@Lazy时,它的实例化将会被推迟到第一次使用时。

总的来说,@Lazy注解可以用于延迟加载Bean,减少系统启动时间。它可以应用于类级别或方法级别,用于控制Bean的实例化时机。在实际项目中,我们可以根据具体的需求来决定是否使用@Lazy注解,以提高系统的性能和效率。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
package com.xiangyixiang.www.cloud.business.gateway.configure; import org.springframework.beans.factory.ObjectProvider; import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean; import org.springframework.boot.autoconfigure.http.HttpMessageConverters; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.http.converter.HttpMessageConverter; import org.springframework.web.cors.CorsConfiguration; import org.springframework.web.cors.reactive.CorsWebFilter; import org.springframework.web.cors.reactive.UrlBasedCorsConfigurationSource; import org.springframework.web.util.pattern.PathPatternParser; import java.util.stream.Collectors; /**网关统一配置允许跨域 * zj 解决跨域问题 * @author 张静 */ @Configuration public class CorsConfig { @Bean public CorsWebFilter corsFilter() { CorsConfiguration config = new CorsConfiguration(); config.setAllowCredentials(true); config.addAllowedMethod("*"); config.addAllowedOrigin("http://39.105.36.172:9250"); config.addAllowedHeader("*"); UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(new PathPatternParser()); source.registerCorsConfiguration("/**", config); return new CorsWebFilter(source); } @Bean @ConditionalOnMissingBean public HttpMessageConverters messageConverters(ObjectProvider<HttpMessageConverter<?>> converters) { return new HttpMessageConverters(converters.orderedStream().collect(Collectors.toList())); } }
06-10
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值