详解如何实现SpringBoot的底层注解
一、@Configuration注解
1、基本使用
自定义配置类
/** * 1、@Configuration 告诉SpringBoot这是一个配置类,相当于一个xml配置文件 * * 2、配置类里面使用 @Bean 标注在方法上 来给容器注册组件,默认是单实例的 * * 3、配置类本身也是一个组件 */ @Configuration(proxyBeanMethods = true) public class MyConfig { @Bean public User user01(){ return new User("zhangsan",23); } @Bean public Pet pet01(){ return new Pet("cat"); } }
主程序类
/** * 主程序类 * @SpringBootApplication:这是一个SpringBoot应用 */ @SpringBootApplication public class MainApplication { public static void main(String[] args) { //返回IOC容器 ConfigurableApplicationContext context = SpringApplication.run(MainApplication.class, args); //从容器中获取bean User user = context.getBean(User.class); System.out.println(user); Pet pet = context.getBean("pet01", Pet.class); System.out.println(pet); MyConfig myConfig = context.getBean(MyConfig.class); System.out.println(myConfig); /*如果配置@Configuration(proxyBeanMethods = true),代理对象调用方法从容器中拿组件,SpringBoot总会检查容器中是否有这个组件 * 保持组件的单实例*/ User user1 = myConfig.user01(); User user2 = myConfig.user01(); System.out.println(user1 == user2); } }
打印结果:
2、Full模式与Lite模式
Full
模式是指proxyBeanMethods = true
,开启代理bean的方法。此时调用配置类中每一个给而容器注册组件方法,都会从容器中找组件,保持单例模式。
/*如果配置@Configuration(proxyBeanMethods = true),代理对象调用方法从容器中拿组件,SpringBoot总会检查容器中是否有这个组件 * 保持组件的单实例*/ User user1 = myConfig.user01(); User user2 = myConfig.user01(); System.out.println(user1 == user2); //true
Lite
模式是指proxyBeanMethods = false
,关闭代理bean的方法。容器中不会保存代理对象,每一次调用配置类里面的方法,·都会产生一个新的对象。这可以解决组件依赖的问题。
User
组件里面有Pet
组件
public class User { private String name; private Integer age; private Pet pet; public Pet getPet() { return pet; } }
自定义的配置类中proxyBeanMethods
设置为false
@Configuration(proxyBeanMethods = false) public class MyConfig { @Bean public User user01(){ User user = new User("zhangsan", 23); //User组件依赖了Pet组件 user.setPet(pet01()); return user; } @Bean public Pet pet01(){ return new Pet("cat"); } }
主程序类
@SpringBootApplication public class MainApplication { public static void main(String[] args) { User user01 = context.getBean("user01", User.class); Pet pet01 = context.getBean("pet01", Pet.class); System.out.println(user01.getPet() == pet01); //true } }
打印结果:
- 配置类组件之间无依赖关系用
Lite
模式加速容器启动过程,减少判断 - 配置类组件之间有依赖关系,方法会被调用得到之前单实例组件,这时要用
Full
模式
二、@Import注解导入组件
@Import
注解可以给容器中自动创建出指定类型的组件,默认组件的名字就是全类名
@Import(DBHelper.class) @Configuration(proxyBeanMethods = false) public class MyConfig { }
在容器中或者这个导入的组件
三、@Conditional注解条件装配
满足Conditional
指定的条件的方法,则进行组件注入
也可以标注在类上,当容器中存在指定的组件的时候,配置类中的方法才会生效
四、@ImportResource注解导入Spring配置文件
外部配置文件
导入外部配置文件
获取导入的外部组件
五、@ConfigurationProperties注解配置绑定
JavaBean与配置文件中属性进行绑定
需要使用@ConfigurationProperties
和 @Component
两个注解,@Component
注解将组件注册到容器中,因为只有在容器中的组件,才能使用SpringBoot提供的一些强大的注解功能
访问请求获取绑定的JavaBean
还可以在配置类中使用@EnableConfigurationProperties
开启组件属性配置功能,并把这个组件自动注册到容器中,这样就不需要再使用 @Component
注解
@EnableConfigurationProperties(Pet.class) public class MyConfig { }
//@Component @ConfigurationProperties(prefix = "mydog") public class Pet { }
依然可以访问请求获取绑定的JavaBean
到此这篇关于详解如何实现SpringBoot的底层注解的文章就介绍到这了,更多相关SpringBoot底层注解内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!