1.7、@import和@Bean的区别,以及ImportSelector和ImportBeanDefinitionRegistrar两个接口的简单实用

实用@Bean和@Import的示例

@Configuration
@Import({Dog.class, Cat.class})
public class DemoConfig {
    @Bean("tom")
    public Person getPerson3(){
        System.out.println("没有添加@condition的普通bean:tom");
        return new Person(1,"tom",12);
    }
}

运行结果:

demoConfig
cn.enjoy.bean.Dog
cn.enjoy.bean.Cat
tom

从这里可以看出@import和@bean的区别

1、@import的id为全类名

2、@import使用更多功能

ImportSelector的使用,可以更加灵活加载bean

public class HonryImportSeletor implements ImportSelector {
    @Override
    public String[] selectImports(AnnotationMetadata importingClassMetadata) {
        return new String[]{"cn.enjoy.bean.Tiger","cn.enjoy.bean.Fish"};
    }
}

加入到配置类中

@Configuration
@Import({Dog.class, Cat.class,HonryImportSeletor.class})
public class DemoConfig {
    @Bean("tom")
    public Person getPerson3(){
        System.out.println("没有添加@condition的普通bean:tom");
        return new Person(1,"tom",12);
    }
}

执行结果:

demoConfig
cn.enjoy.bean.Dog
cn.enjoy.bean.Cat
cn.enjoy.bean.Tiger
cn.enjoy.bean.Fish
tom

ImportBeanDefinitionRegistrar接口的使用,可以通过条件控制想要加载的bean

public class HonryImportBeanDefinitionRegister implements ImportBeanDefinitionRegistrar {
    @Override
    public void registerBeanDefinitions(AnnotationMetadata importingClassMetadata, BeanDefinitionRegistry registry) {
        boolean b = registry.containsBeanDefinition("cn.enjoy.bean.Dog");
        boolean b1 = registry.containsBeanDefinition("cn.enjoy.bean.Fish");
//通过判断dog和fish在IOC容器中,才加载pig
        if(b && b1){
            RootBeanDefinition definition = new RootBeanDefinition(Pig.class);
            registry.registerBeanDefinition("cn.enjoy.bean.Pig",definition);
        }
    }
}

配置@import加上

@Configuration
@Import({Dog.class, Cat.class,HonryImportSeletor.class,HonryImportBeanDefinitionRegister.class})
public class DemoConfig {
    @Bean("tom")
    public Person getPerson3(){
        System.out.println("没有添加@condition的普通bean:tom");
        return new Person(1,"tom",12);
    }
}

输出结果:

demoConfig
cn.enjoy.bean.Dog
cn.enjoy.bean.Cat
cn.enjoy.bean.Tiger
cn.enjoy.bean.Fish
tom
cn.enjoy.bean.Pig

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Java 1.7中,`@ConfigurationProperties`注解是Spring Boot框架中用于将配置文件中的属性值绑定到Java Bean的注解。它可以帮助我们更方便地管理和使用配置文件中的属性。 下面是一个使用`@ConfigurationProperties`注解的示例: ```java @ConfigurationProperties(prefix = "myconfig") public class MyConfigurationProperties { private String property1; private int property2; // 其他属性... // getter和setter方法... } ``` 在上面的示例中,`@ConfigurationProperties`注解的`prefix`属性指定了配置文件中属性的前缀,这里是`myconfig`。然后,我们可以在`MyConfigurationProperties`类中定义与配置文件中属性对应的字段,并提供相应的getter和setter方法。 接下来,我们需要在启动类或配置类上使用`@EnableConfigurationProperties`注解来启用`@ConfigurationProperties`注解的类。例如: ```java @SpringBootApplication @EnableConfigurationProperties(MyConfigurationProperties.class) public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` 这样,当应用程序启动时,Spring Boot会自动将配置文件中以`myconfig`为前缀的属性值绑定到`MyConfigurationProperties`类的实例中。 请注意,`@ConfigurationProperties`注解需要与`@Component`或其派生注解一起使用,以便将其作为Spring Bean进行管理。如果只使用`@ConfigurationProperties`注解而没有使用`@Component`或其派生注解,那么在IOC容器中是无法获取到该类的实例的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值