3.Spring源码之路-DefaulListableBeanFactory - SingletonBeanRegistry

Spring源码之路-DefaulListableBeanFactory

SingletonBeanRegistry接口总结

  1. SingletonBeanRegistry的主要作用是提供注册入口,凡是注册进来的Bean
    都是已经被实例化后的,因为Bean都已经实例化过了,所以不会触发Bean生
    命周期中的方法.
    • void registerSingleton(String beanName, Object singletonObject);
  2. 同样也提供了相关的查询方法.
    • Object getSingleton(String beanName)
    • String[] getSingletonNames();
  3. 关于对实例是否存在的判断
    • boolean containsSingleton(String beanName);
  4. 对实例的统计
    • int getSingletonCount();
  5. 获取锁对象,以保证线程的安全问题
    • Object getSingletonMutex();

源码注释的大概翻译

/**
 * 为共享bean实例定义注册表的接口。
 * 可以由{@link org.springframework.beans.factory.BeanFactory}实现,
 * 以便以统一的方式公开其单例管理工具。 
 * {@ link ConfigurableBeanFactory}接口扩展了此接口。
 * @author Juergen Hoeller
 * @since 2.0
 * @see ConfigurableBeanFactory
 * @see org.springframework.beans.factory.support.DefaultSingletonBeanRegistry
 * @see org.springframework.beans.factory.support.AbstractBeanFactory
 */
public interface SingletonBeanRegistry {

	/**
	 * 在给定的bean名称下,在bean注册表中将给定的现有对象注册为单例。
	 * 该给定实例应该被完全初始化;注册表将不会执行任何初始化回调
	 * 特别是不会调用InitializingBean的{@code afterPropertiesSet}方法)
	 * 给定的实例也不会接收任何销毁回调
	 * 例如DisposableBean的{@code destroy}方法)。 
	 * 在完整的BeanFactory中运行时:注册一个BeanDefinition
	 * 而不是现有实例,如果您的bean应该接收初始化和/或销毁回调。
	 * 通常在调用过程中调用注册表配置,但也可以用于单例的运行时注册。
	 * 因此,注册表实现应同步单例访问;如果它支持BeanFactory的单例延
	 * 迟初始化,则无论如何都必须这样做。 
	 * @param beanName bean的名称
	 * @param singletonObject 现有的单例对象
	 * @see org.springframework.beans.factory.InitializingBean#afterPropertiesSet
	 * @see org.springframework.beans.factory.DisposableBean#destroy
	 * @see org.springframework.beans.factory.support.BeanDefinitionRegistry#registerBeanDefinition
	 */
	void registerSingleton(String beanName, Object singletonObject);

	/**
	 * 返回以给定名称注册的(原始)单例对象。 
	 * 仅检查已实例化的单例;对于尚未实例化的单例bean定义,不返回Object。
	 * 此方法的主要目的是访问手动注册的单例,(请参阅{@link #registerSingleton})。
	 * 也可以用于以原始方式访问由已创建的bean定义定义的单例。 
	 * 注意:此查找方法不知道FactoryBean前缀或别名。 
	 * 在获取单例实例之前,您需要首先解析规范化的bean名称。 
	 * @param 要查找的bean的名称
	 * @return 返回注册的单例对象,如果找不到,则为{@code null} 
	 * @see ConfigurableListableBeanFactory#getBeanDefinition
	 */
	@Nullable
	Object getSingleton(String beanName);

	/**
	 * 检查此注册表是否包含具有给定名称的单例实例。 
	 * 仅检查已实例化的单例;对于尚未实例化的单例bean定义,不返回{@code true} 
	 * 此方法的主要目的是检查手动注册的单例
	 * (请参阅{@link #registerSingleton})。也可以用于检查是否已创建由bean定义定义的单例。
	 * 要检查bean工厂是否包含具有给定名称的bean定义,请使用ListableBeanFactory的
	 * {@code containsBeanDefinition}。调用{@code containsBeanDefinition}和
	 * {@code containsSingleton}都可以知道特定的bean工厂是否包含具有给定名称的本地bean实例。
	 * 使用BeanFactory的{@code containsBean}进行常规检查,检查工厂是否知道给定名称的bean
	 * (无论是手动注册的singleton 实例还是由bean定义创建的),还检查父工厂。
	 * 注意:此查找方法不知道FactoryBean前缀或别名。 在检查单例状态之前,您需要首先解析规
	 * 范的bean名称。 
	 * @param 要查找的bean的名称
	 * @return 如果此bean工厂包含具有给定名称的单例实例,则返回{@code true},否则返回
	 * {@code false}
	 * @see #registerSingleton
	 * @see org.springframework.beans.factory.ListableBeanFactory#containsBeanDefinition
	 * @see org.springframework.beans.factory.BeanFactory#containsBean
	 */
	boolean containsSingleton(String beanName);

	/**
	 * 返回在此注册表中注册的单例bean的名称。 
	 * 仅检查已实例化的单例;对于尚未实例化的单例bean定义,不返回名称
	 * 此方法的主要目的是检查手动注册的单例
	 * (请参阅{@link #registerSingleton})。也可以用来检查由beanDefinition定义的单例已经创建。 
	 * @return 将名称列表作为String数组返回(绝不{@code null})
	 * @see #registerSingleton
	 * @see org.springframework.beans.factory.support.BeanDefinitionRegistry#getBeanDefinitionNames
	 * @see org.springframework.beans.factory.ListableBeanFactory#getBeanDefinitionNames
	 */
	String[] getSingletonNames();

	/**
	 * 返回在此注册表中注册的单例bean的数量。 
	 * 仅检查已实例化的单例;不计算尚未实例化的单例beanDefinition。 
	 * 此方法的主要目的是检查手动注册的单例(请参阅{@link #registerSingleton})。
	 * 也可以用于计算已由bean定义定义的单例的数量。 
	 * @return 返回单例bean的数量
	 * @see #registerSingleton
	 * @see org.springframework.beans.factory.support.BeanDefinitionRegistry#getBeanDefinitionCount
	 * @see org.springframework.beans.factory.ListableBeanFactory#getBeanDefinitionCount
	 */
	int getSingletonCount();

	/**
	 * 返回此注册表使用的单例互斥体(对于外部协作者)。 
	 * 这里的单例互斥体,其实就是锁,防止多线程的并发的问题
	 * @return 返回互斥对象(永不{@code null})
	 * @since 4.2
	 */
	Object getSingletonMutex();

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值