SpringBoot底层注解@Configuration
在spring中我们需要写配置文件来扫描bean,给bean注入值,在springboot中的@Configuration是作用在类上的,这就好比我们以前写的配置文件,以前我们对bean进行注入需要在xml文件里进行配置,然而在springboot中我们只需要在方法上添加@Bean注解这样的话我们就把bean放入了springboot的容器中。
具体代码演示
- 先来一个实体类pet
package com.xu.demo.bean;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@NoArgsConstructor
@AllArgsConstructor
public class pet {
private String name;
private int age;
}
- 接着在写我们的配置类MyConfig
package com.xu.demo.config;
import com.xu.demo.bean.pet;
import com.xu.demo.bean.user;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration(proxyBeanMethods = true)
public class MyConfig {
@Bean
public pet tomcat(){
return new pet("tomcat",18);
}
}
这样的话我们就把tomcat放到了springboot的容器中,这个方法名就是它的id,同样也是可以自定义的,源码如下,直接加入值就可以
@AliasFor("name")
String[] value() default {};
proxyBeanMethods = true
这个可以这样理解,它的默认属性是true,对应的也就是springboot中的full模式(全模式),我们在springboot的容器中获取了我们刚才写的配置文件也就是组件
MyConfig bean = run.getBean(MyConfig.class);
接着我们在调用他的方法 输出结果为true
pet tomcat1 = bean.tomcat();
pet tomcat2 = bean.tomcat();
System.out.println("这2个pet是不是容器中的pet:"+(tomcat1==tomcat2));
因为我们把组件放到容器中,在这个时候,这个pet就已经被new出来放到容器中了,这时候proxyBeanMethods = true,默认开启了代理,无论是tomcat1还是tomcat2他们都是取得容器里的pet,所以他们是一样的,但是这样效率不是太高,需要在容器中去查找。
验证
@Bean
public pet tomcat(){
System.out.println("我被放入容器里了");
return new pet("tomcat",18);
}
proxyBeanMethods = false
改为false也就是lite模式(轻量模式),就是它不会在容器里寻找,而是在获取到这个bean的时候,再去new出来这个pet
在这里可以看到它没有在容器里去找而是被new了出来,这样的话这两只tomcat肯定是不一样的。但是这样大效率比较高,因为不需要在容器里去寻找。