ListableBeanFactory解读
ListableBeanFactory解读
ListableBeanFactory介绍
ListableBeanFactory是BeanFactory的子接口,除了BeanFactory的功能外,还格外定义一些能遍历和查找BeanDefinition的方法。
ListableBeanFactory源码
上网找了个翻译,其实也不用细看,就是一些遍历和查找BeanDefinition的方法
public interface ListableBeanFactory extends BeanFactory {
/**
* 查看是否包含指定名字的Bean
* 不支持向上或向下查找
* 不支持查找非配置文件定义的单例Bean
*/
boolean containsBeanDefinition(String beanName);
/**
* 查看此BeanFactory中包含的Bean数量
* 不支持向上或向下查找
* 不支持查找非配置文件定义的单例Bean
*/
int getBeanDefinitionCount();
/**
* 返回此BeanFactory中所包含的所有Bean定义的名称
* 不支持向上或向下查找
* 不支持查找非配置文件定义的单例Bean
*/
String[] getBeanDefinitionNames();
/**
* 返回此BeanFactory中所有指定类型的Bean的名字。判断是否是指定类型的标准有两个:a Bean定义。
* b FactoryBean的getObjectType方法。
* 只考虑最顶层的Bean,对于嵌套的Bean,即使符合类型也不予考虑
* 会考虑FactoryBean创建出的Bean
* 不支持向上或向下查找
* 不支持查找非配置文件定义的单例Bean
* 此签名的getBeanNamesForType方法会返回所有Scope类型的Bean,在大多数的实现中,其返回结果和
* 其重载方法getBeanNamesForType(type, true, true)返回结果一致。
* 返回结果中,Bean名字的顺序应该和其定义时一样
*/
String[] getBeanNamesForType(ResolvableType type);
/**
* 返回此BeanFactory中所有指定类型(或指定类型的子类型)的Bean的名字。判断是否是指定类型的标准有
* 两个:a Bean定义,b FactoryBean的getObjectType方法。
* 只考虑最顶层的Bean,对于嵌套的Bean,即使符合类型也不予考虑
* 会考虑FactoryBean创建出的Bean
* 不支持向上或向下查找
* 不支持查找非配置文件定义的单例Bean
* 此签名的getBeanNamesForType方法会返回所有Scope类型的Bean,在大多数的实现中,其返回结果和
* 其重载方法getBeanNamesForType(type, true, true)返回结果一致。
* 返回结果中,Bean名字的顺序应该和其定义时一样
*/
String[] getBeanNamesForType(Class<?> type);
/**
* 返回此BeanFactory中所有指定类型(或指定类型的子类型)的Bean的名字。判断是否是指定类型的标准有
* 两个:a Bean定义,b FactoryBean的getObjectType方法。
* 只考虑最顶层的Bean,对于嵌套的Bean,即使符合类型也不予考虑
* 会考虑FactoryBean创建出的Bean
* 不支持向上或向下查找
* 不支持查找非配置文件定义的单例Bean
* 此签名的getBeanNamesForType方法会返回所有Scope类型的Bean,在大多数的实现中,其返回结果和
* 其重载方法getBeanNamesForType(type, true, true)返回结果一致。
* 返回结果中,Bean名字的顺序应该和其定义时一样
* 如果Bean是通过FactoryBean创建的,那么只考虑设置了allowEagerInit标志位的Bean。如果
* 没有设置allowEagerInit标志位,则只考虑FactoryBean的类型
*/
String[] getBeanNamesForType(Class<?> type, boolean includeNonSingletons, boolean allowEagerInit);
/**
* 返回此BeanFactory中所有指定类型(或指定类型的子类型)的Bean的名字。判断是否是指定类型的标准有
* 两个:a Bean定义,b FactoryBean的getObjectType方法。
* 只考虑最顶层的Bean,对于嵌套的Bean,即使符合类型也不予考虑
* 会考虑FactoryBean创建出的Bean
* 不支持向上或向下查找
* 不支持查找非配置文件定义的单例Bean
* 此签名的getBeanNamesForType方法会返回所有Scope类型的Bean,在大多数的实现中,其返回结果和
* 其重载方法getBeanNamesForType(type, true, true)返回结果一致。
* 返回结果中,Bean名字的顺序应该和其定义时一样
*/
<T> Map<String, T> getBeansOfType(Class<T> type) throws BeansException;
/**
* 返回此BeanFactory中所有指定类型(或指定类型的子类型)的Bean的名字。判断是否是指定类型的标准有
* 两个:a Bean定义,b FactoryBean的getObjectType方法。
* 只考虑最顶层的Bean,对于嵌套的Bean,即使符合类型也不予考虑
* 会考虑FactoryBean创建出的Bean
* 不支持向上或向下查找
* 不支持查找非配置文件定义的单例Bean
* 此签名的getBeanNamesForType方法会返回所有Scope类型的Bean,在大多数的实现中,其返回结果和
* 其重载方法getBeanNamesForType(type, true, true)返回结果一致。
* 返回结果中,Bean名字的顺序应该和其定义时一样
* 如果Bean是通过FactoryBean创建的,那么只考虑设置了allowEagerInit标志位的Bean。如果
* 没有设置allowEagerInit标志位,则只考虑FactoryBean的类型
* @see BeanFactoryUtils#beansOfTypeIncludingAncestors(ListableBeanFactory, Class, boolean, boolean)
*/
<T> Map<String, T> getBeansOfType(Class<T> type, boolean includeNonSingletons, boolean allowEagerInit)
throws BeansException;
/**
* 找到所有带有指定注解类型的Bean
*/
String[] getBeanNamesForAnnotation(Class<? extends Annotation> annotationType);
/**
* 找到所有带有指定注解的Bean,返回一个以Bean的name为键,其对应的Bean实例为值的Map
*/
Map<String, Object> getBeansWithAnnotation(Class<? extends Annotation> annotationType) throws BeansException;
/**
* 在指定name对应的Bean上找指定的注解,如果没有找到的话,去指定Bean的父类或者父接口上查找
*/
<A extends Annotation> A findAnnotationOnBean(String beanName, Class<A> annotationType)
throws NoSuchBeanDefinitionException;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)