@Configuration

简介: 被 `@Configuration` 标注的类视为Spring配置类,相当于XML配置文件。通过 `@Bean` 注解注册Bean,配合 `AnnotationConfigApplicationContext` 初始化容器,可加载并管理所有Bean组件。

@Configuration 标注的类,会被 Spring 的IOC容器认定为配置类。

一个被 @Configuration 标注的类,相当于一个 applicationContext.xml 的配置文件。


例如:声明一个类,并标注 @Configuration 注解:

@Configuration
public class ConfigurationDemo {
    @Bean
    public Date currentDate() {
        return new Date();
    }
}

上述注册Bean的方式类比于xml:

<bean id="currentDate" class="java.util.Date"/> 

之后使用注解启动方式,初始化一个IOC容器,并打印IOC容器中的所有bean的name:

public class MainApp {
    public static void main(String[] args) throws Exception {
        AnnotationConfigApplicationContext ctx = new AnnotationConfigApplicationContext(ConfigurationDemo.class);
        String[] beanDefinitionNames = ctx.getBeanDefinitionNames();
        Stream.of(beanDefinitionNames).forEach(System.out::println);
    }
}

输出结果:

org.springframework.context.annotation.internalConfigurationAnnotationProcessor
org.springframework.context.annotation.internalAutowiredAnnotationProcessor
org.springframework.context.annotation.internalCommonAnnotationProcessor
org.springframework.context.event.internalEventListenerProcessor
org.springframework.context.event.internalEventListenerFactory
configurationDemo
currentDate

可以发现组件,以及配置类本身被成功加载。

相关文章
|
4月前
|
Java
ArrayList 的扩容机制解析
ArrayList扩容机制解析:添加元素时先检查容量,不足则触发扩容。默认初始容量为10,每次扩容1.5倍,通过数组拷贝实现,耗时O(n)。频繁扩容影响性能,建议预估容量并初始化指定大小,提升效率。
|
4月前
|
运维 监控 安全
为什么禁止使用 Executors 创建线程池?
Java并发中,`Executors`快捷方法易导致OOM或系统雪崩,因隐藏关键配置。阿里手册禁止其在生产使用。应显式创建`ThreadPoolExecutor`,设定核心参数与有界队列,结合Guava命名线程,提升系统稳定性与可维护性。
|
4月前
|
SQL 监控 安全
如何做好 SQL 质量监控:从“盲跑查询”到“可观测分析”
本文详解SQL质量监控的五大核心维度:使用概览、性能表现、成功率、成本消耗与行为审计,结合阿里云SLS实践,帮助企业实现从被动排查到主动治理的转变,保障系统稳定、控制成本、满足合规要求,让每一条SQL查询都清晰可控、值得信赖。
|
4月前
|
安全 Java Spring
2-FilterChainProxy
本文通过源码分析Spring Security中的FilterChainProxy,揭示其如何将多个过滤器封装进SecurityFilterChain,并逐步调试验证过滤器链的加载与执行过程,最终确认FilterChainProxy正是真正执行的安全过滤器链核心。
2-FilterChainProxy
|
4月前
|
存储 安全
3.OAuth2.0四种授权模式
本文详解OAuth2授权码模式流程:A服务客户端通过B服务认证服务,经用户授权获取授权码,再换取访问令牌,从而安全调用B服务资源。该模式安全性高,广泛应用于第三方登录场景。
3.OAuth2.0四种授权模式
|
4月前
|
安全 Java Spring
1-DelegatingFilterProxy
本文解析了Spring Security中DelegatingFilterProxy的源码执行流程。通过web.xml配置,该过滤器根据名称springSecurityFilterChain从容器中获取FilterChainProxy实例,并在doFilter中委托其处理请求,实现安全过滤链的调用。
|
4月前
|
安全 Java
ArrayList 扩容机制详解:从第 1 个到第 11 个元素
ArrayList动态扩容详解:首次添加元素时扩容至10,后续按1.5倍增长。通过`grow()`方法实现,结合位运算优化性能,扩容代价较高,建议预设初始容量以提升效率,体现“空间换时间”设计思想。(238字)
|
4月前
|
SQL 前端开发 测试技术
如何写好一篇技术方案(精简版)
一份好的技术方案是推动项目落地、对齐认知、降低协作成本的关键。应包含变更记录、背景、功能模块、流程图、接口设计等十大结构,遵循图文结合、聚焦可执行、简洁明了的原则,800–1500字为宜,重在指导行动而非堆砌文字。
|
4月前
|
安全 Java 关系型数据库
OAuth2.0实战案例
本节介绍如何创建资源模块,配置Spring Boot项目依赖,集成Security、OAuth2、MyBatis及MySQL,实现安全认证与数据访问,构建基础架构。
|
4月前
|
前端开发 小程序 JavaScript
简化模式
简化模式下,A服务客户端直接与B服务交互,无授权码,token经回调地址返回,适用于无后端的纯前端应用。密码模式中,用户直接向A客户端提供B服务账号密码以获取token,流程简单但需高度信任,适合可信度高的服务间使用。(238字)

热门文章

最新文章