深度解析 Spring 源码:揭秘 BeanFactory 之谜

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
简介: 深度解析 Spring 源码:揭秘 BeanFactory 之谜

深度解析 Spring 源码:揭秘 BeanFactory 之谜

 

`BeanFactory` 是 Spring 框架的核心接口之一,用于管理和配置应用中的 Bean。它提供了一种统一的方式来访问应用程序组件,并管理这些组件的生命周期。理解 `BeanFactory` 及其相关实现类对于深入掌握 Spring 容器的工作机制至关重要。

 

1. BeanFactory 的概述

 

`BeanFactory` 是一个简单的 IOC(Inversion of Control)容器,负责实例化、配置和管理 Bean。它是所有 Spring 容器的基础接口,定义了最基本的 Bean 管理操作。

 

主要功能包括:

- 实例化和获取 Bean

- 管理 Bean 的生命周期

- 处理 Bean 之间的依赖关系

 

2. BeanFactory 的层次结构

 

Spring 提供了多种 `BeanFactory` 的实现,满足不同的使用场景。主要的子接口和实现类包括:

 

- **ListableBeanFactory**: 扩展了 `BeanFactory`,增加了按类型或其他标准批量查找 Bean 的能力。

- **HierarchicalBeanFactory**: 增加了父子级别的 BeanFactory 支持。

- **ConfigurableBeanFactory**: 提供了配置 BeanFactory 的方法,以及注册 Bean 处理器和作用域的支持。

- **DefaultListableBeanFactory**: 常用的具体实现类,结合了 `ListableBeanFactory` 和 `ConfigurableBeanFactory` 的功能。

 

3. BeanFactory 接口源码

 

以下是 `BeanFactory` 接口的简化版源码:

 

```java
public interface BeanFactory {
 
    // 按名称获取 Bean
    Object getBean(String name) throws BeansException;
 
    // 按名称和类型获取 Bean
    <T> T getBean(String name, Class<T> requiredType) throws BeansException;
 
    // 按类型获取 Bean
    <T> T getBean(Class<T> requiredType) throws BeansException;
 
    // 按名称和构造函数参数获取 Bean
    Object getBean(String name, Object... args) throws BeansException;
 
    // 检查是否包含指定名称的 Bean
    boolean containsBean(String name);
 
    // 判断指定名称的 Bean 是否为单例
    boolean isSingleton(String name) throws NoSuchBeanDefinitionException;
 
    // 判断指定名称的 Bean 是否为原型
    boolean isPrototype(String name) throws NoSuchBeanDefinitionException;
 
    // 获取指定名称的 Bean 的类型
    Class<?> getType(String name) throws NoSuchBeanDefinitionException;
}
```

 

4. DefaultListableBeanFactory 类

 

`DefaultListableBeanFactory` 是 Spring 中最常用的 `BeanFactory` 实现类,它结合了多个接口的功能,提供了强大的 Bean 管理能力。以下是 `DefaultListableBeanFactory` 类的一些关键代码:

 

```java
public class DefaultListableBeanFactory extends AbstractAutowireCapableBeanFactory
                                        implements ConfigurableListableBeanFactory,
                                                   BeanDefinitionRegistry {
    private final Map<String, BeanDefinition> beanDefinitionMap = new ConcurrentHashMap<>(256);
 
    @Override
    public void registerBeanDefinition(String beanName, BeanDefinition beanDefinition)
            throws BeanDefinitionStoreException {
        Assert.hasText(beanName, "Bean name must not be empty");
        Assert.notNull(beanDefinition, "BeanDefinition must not be null");
 
        this.beanDefinitionMap.put(beanName, beanDefinition);
    }
 
    @Override
    public Object getBean(String name) throws BeansException {
        return doGetBean(name, null, null, false);
    }
 
    @Override
    public <T> T getBean(String name, Class<T> requiredType) throws BeansException {
        return requiredType.cast(getBean(name));
    }
 
    @Override
    public <T> T getBean(Class<T> requiredType) throws BeansException {
        String[] beanNames = getBeanNamesForType(requiredType);
        if (beanNames.length > 1) {
            throw new NoUniqueBeanDefinitionException(requiredType, beanNames);
        }
        return getBean(beanNames[0], requiredType);
    }
 
    @Override
    public boolean containsBean(String name) {
        return containsBeanDefinition(name) || super.containsSingleton(name);
    }
 
    @Override
    public boolean isSingleton(String name) throws NoSuchBeanDefinitionException {
        BeanDefinition bd = getBeanDefinition(name);
        return bd.isSingleton();
    }
 
    @Override
    public boolean isPrototype(String name) throws NoSuchBeanDefinitionException {
        BeanDefinition bd = getBeanDefinition(name);
        return bd.isPrototype();
    }
 
    @Override
    @Nullable
    public Class<?> getType(String name) throws NoSuchBeanDefinitionException {
        BeanDefinition bd = getBeanDefinition(name);
        return bd.getBeanClass();
    }
}
```

 

5. BeanFactory 的使用

 

5.1 通过 XML 配置文件使用 BeanFactory

 

在 XML 配置文件中定义 Bean,然后通过 `XmlBeanFactory` 加载配置文件并获取 Bean:

 

```xml
<beans>
    <bean id="exampleBean" class="com.example.MyClass">
        <property name="name" value="example"/>
    </bean>
</beans>
```
 
```java
Resource resource = new ClassPathResource("applicationContext.xml");
BeanFactory factory = new XmlBeanFactory(resource);
MyClass myClass = factory.getBean("exampleBean", MyClass.class);
```

 

5.2 通过注解配置使用 ApplicationContext

 

虽然 `ApplicationContext` 是 `BeanFactory` 的子接口,但它提供了更多高级功能,如事件发布、国际化等。我们通常使用 `AnnotationConfigApplicationContext` 来加载注解配置:

 

```java
@Configuration
public class AppConfig {
    @Bean
    public MyClass exampleBean() {
        return new MyClass("example");
    }
}
 
ApplicationContext context = new AnnotationConfigApplicationContext(AppConfig.class);
MyClass myClass = context.getBean(MyClass.class);
```

 

6. 总结

 

`BeanFactory` 是 Spring 容器的核心接口,负责 Bean 的创建、管理和生命周期控制。通过对 `BeanFactory` 及其实现类的深入理解,我们可以了解 Spring 容器如何高效地管理应用程序中的组件。无论是简单的 `BeanFactory` 还是功能更丰富的 `ApplicationContext`,它们都基于相同的核心理念,为开发者提供了一致且强大的依赖注入和组件管理机制。

目录
相关文章
|
3天前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
16 2
|
19天前
|
数据采集 监控 前端开发
二级公立医院绩效考核系统源码,B/S架构,前后端分别基于Spring Boot和Avue框架
医院绩效管理系统通过与HIS系统的无缝对接,实现数据网络化采集、评价结果透明化管理及奖金分配自动化生成。系统涵盖科室和个人绩效考核、医疗质量考核、数据采集、绩效工资核算、收支核算、工作量统计、单项奖惩等功能,提升绩效评估的全面性、准确性和公正性。技术栈采用B/S架构,前后端分别基于Spring Boot和Avue框架。
|
22天前
|
搜索推荐 Java Spring
Spring Filter深度解析
【10月更文挑战第21天】Spring Filter 是 Spring 框架中非常重要的一部分,它为请求处理提供了灵活的控制和扩展机制。通过合理配置和使用 Filter,可以实现各种个性化的功能,提升应用的安全性、可靠性和性能。还可以结合具体的代码示例和实际应用案例,进一步深入探讨 Spring Filter 的具体应用和优化技巧,使对它的理解更加全面和深入。
|
9天前
|
前端开发 Java 开发者
Spring生态学习路径与源码深度探讨
【11月更文挑战第13天】Spring框架作为Java企业级开发中的核心框架,其丰富的生态系统和强大的功能吸引了无数开发者的关注。学习Spring生态不仅仅是掌握Spring Framework本身,更需要深入理解其周边组件和工具,以及源码的底层实现逻辑。本文将从Spring生态的学习路径入手,详细探讨如何系统地学习Spring,并深入解析各个重点的底层实现逻辑。
35 9
|
4天前
|
存储 安全 Linux
Golang的GMP调度模型与源码解析
【11月更文挑战第11天】GMP 调度模型是 Go 语言运行时系统的核心部分,用于高效管理和调度大量协程(goroutine)。它通过少量的操作系统线程(M)和逻辑处理器(P)来调度大量的轻量级协程(G),从而实现高性能的并发处理。GMP 模型通过本地队列和全局队列来减少锁竞争,提高调度效率。在 Go 源码中,`runtime.h` 文件定义了关键数据结构,`schedule()` 和 `findrunnable()` 函数实现了核心调度逻辑。通过深入研究 GMP 模型,可以更好地理解 Go 语言的并发机制。
|
16天前
|
消息中间件 缓存 安全
Future与FutureTask源码解析,接口阻塞问题及解决方案
【11月更文挑战第5天】在Java开发中,多线程编程是提高系统并发性能和资源利用率的重要手段。然而,多线程编程也带来了诸如线程安全、死锁、接口阻塞等一系列复杂问题。本文将深度剖析多线程优化技巧、Future与FutureTask的源码、接口阻塞问题及解决方案,并通过具体业务场景和Java代码示例进行实战演示。
37 3
|
30天前
|
XML Java 数据格式
Spring IOC容器的深度解析及实战应用
【10月更文挑战第14天】在软件工程中,随着系统规模的扩大,对象间的依赖关系变得越来越复杂,这导致了系统的高耦合度,增加了开发和维护的难度。为解决这一问题,Michael Mattson在1996年提出了IOC(Inversion of Control,控制反转)理论,旨在降低对象间的耦合度,提高系统的灵活性和可维护性。Spring框架正是基于这一理论,通过IOC容器实现了对象间的依赖注入和生命周期管理。
65 0
|
2月前
|
SQL 监控 druid
springboot-druid数据源的配置方式及配置后台监控-自定义和导入stater(推荐-简单方便使用)两种方式配置druid数据源
这篇文章介绍了如何在Spring Boot项目中配置和监控Druid数据源,包括自定义配置和使用Spring Boot Starter两种方法。
|
1月前
|
人工智能 自然语言处理 前端开发
SpringBoot + 通义千问 + 自定义React组件:支持EventStream数据解析的技术实践
【10月更文挑战第7天】在现代Web开发中,集成多种技术栈以实现复杂的功能需求已成为常态。本文将详细介绍如何使用SpringBoot作为后端框架,结合阿里巴巴的通义千问(一个强大的自然语言处理服务),并通过自定义React组件来支持服务器发送事件(SSE, Server-Sent Events)的EventStream数据解析。这一组合不仅能够实现高效的实时通信,还能利用AI技术提升用户体验。
162 2
|
8天前
|
缓存 IDE Java
SpringBoot入门(7)- 配置热部署devtools工具
SpringBoot入门(7)- 配置热部署devtools工具
20 2
 SpringBoot入门(7)- 配置热部署devtools工具

推荐镜像

更多