/** * Resolve an inner bean definition. */ private Object resolveInnerBeanDefinition(String innerBeanName, BeanDefinition innerBd) throws BeansException { if (logger.isDebugEnabled()) { logger.debug("Resolving inner bean definition '" + innerBeanName + "' of bean '" + this.beanName + "'"); } RootBeanDefinition mergedInnerBd = this.beanFactory.getMergedBeanDefinition(innerBeanName, innerBd); Object innerBean = this.beanFactory.createBean(innerBeanName, mergedInnerBd, null); if (mergedInnerBd.isSingleton()) { this.beanFactory.registerDependentBean(innerBeanName, this.beanName); } return this.beanFactory.getObjectForSharedInstance(innerBeanName, innerBean); }
logger.debug("Returning cached instance of singleton bean '" + beanName + "'"); bean = getObjectForSharedInstance(name, sharedInstance); bean = getObjectForSharedInstance(name, sharedInstance);