Configuration注解的proxyBeanMethods属性学习
proxyBeanMethods属性学习小记
实体类:User和Pet User类:
/** * @author Frank * @version 1.0 * @date 2022/3/11 */ @Data @NoArgsConstructor @AllArgsConstructor @ToString public class User { private String name; private int age; private Pet pet; }
Pet类:
/** * @author Frank * @version 1.0 * @date 2022/3/11 */ @Data @NoArgsConstructor @AllArgsConstructor @ToString public class Pet { private String breed; }
User类中的pet属性类型是Pet类,即User的Bean依赖于Pet 当proxyBeanMethods=false时,使用依赖注入IDEA会报红,但是不影响运行!!! 报红显示内容为:Method annotated with @Bean is called directly in a @Configuration where proxyBeanMethods set to false. Set proxyBeanMethods to true or use dependency injection.·
译文:用@ bean注释的方法是直接调用在@ configuration proxyBeanMethods设置为false。需要proxyBeanMethods设置为true或使用依赖注入。
测试代码及结果:
//proxyBeanMethods=false测试依赖注入 User u3 = myConfig.user01(); Pet p31 = u3.getPet(); Pet p1 = myConfig.pet01(); //结果为false,即不是同一个,则无法实现依赖注入!!! System.out.println("u3中的p31是否和p1相同:" + (p31 == p1));
proxyBeanMethods=false时:
proxyBeanMethods=true时:
查阅资料得知,这是SpringBoot2版本之后官方新增的一个很强大很实用的属性,当:
-
proxyBeanMethods=true时为全局模式,外部调用@Bean注解的方法时,会去容器中检查是否已经存在这个组件,如果存在,则不再创建;如不存在,则创建! proxyBeanMethods-false时为轻量模式,调用@Bea方法时,会跳过去容器中检查组件是否存在的这个机制,直接创建!
上一篇:
通过多线程提高代码的执行效率例子