spring中的@ComponentScan注解详解

news2025/7/19 11:08:29

@ComponentScan 是 Spring 框架中用于自动扫描并注册组件的核心注解,它简化了 Spring 应用中 Bean 的发现和装配流程。以下从核心功能、属性解析、使用场景及示例等方面进行详细说明。


一、核心功能与作用

  1. 自动扫描组件
    @ComponentScan 会扫描指定包及其子包下的类,识别并注册标注了 @Component@Service@Repository@Controller 等注解的类为 Spring Bean。

  2. 替代 XML 配置
    与 XML 配置 <context:component-scan> 功能等价,但通过注解实现更简洁的配置。

  3. 支持自定义过滤规则
    通过 includeFiltersexcludeFilters 属性,灵活控制扫描范围,例如仅包含特定注解的类或排除某些包。


二、主要属性解析

属性默认值说明
value / basePackages指定扫描的包路径(字符串或数组形式),如 @ComponentScan("com.example")
basePackageClasses根据指定类的包路径扫描其所在包及子包,如 @ComponentScan(basePackageClasses = Demo.class)
useDefaultFilterstrue是否启用默认过滤规则(扫描 @Component 等注解的类)。设为 false 时需自定义 includeFilters
includeFilters包含的过滤规则(数组),如仅扫描带有 @Service 注解的类。
excludeFilters排除的过滤规则(数组),如排除 @Controller 注解的类。
lazyInitfalse是否延迟初始化扫描到的 Bean(Spring 4.1+ 支持)。

三、过滤规则(FilterType)

@ComponentScan 支持多种过滤类型,通过 FilterType 指定:

  1. ANNOTATION
    按注解过滤,如仅扫描 @Service 注解的类:

    @ComponentScan(includeFilters = @Filter(type = FilterType.ANNOTATION, classes = Service.class))
    
  2. ASSIGNABLE_TYPE
    按类或其子类过滤,如扫描 Animal 类及其子类:

    @ComponentScan(includeFilters = @Filter(type = FilterType.ASSIGNABLE_TYPE, classes = Animal.class))
    
  3. CUSTOM
    自定义过滤规则,需实现 TypeFilter 接口。例如仅扫描类名含 Controller 的类:

    public class CustomFilter implements TypeFilter {
        @Override
        public boolean match(MetadataReader metadataReader, ...) {
            return metadataReader.getClassMetadata().getClassName().contains("Controller");
        }
    }
    

    配置:

    @ComponentScan(includeFilters = @Filter(type = FilterType.CUSTOM, classes = CustomFilter.class))
    
  4. ASPECTJ/REGEX
    分别通过 AspectJ 表达式或正则表达式匹配类名。


四、使用示例

  1. 基本用法

    @Configuration
    @ComponentScan("com.example.service") // 扫描指定包
    public class AppConfig {}
    
  2. 多包扫描与过滤

    @ComponentScan(
        basePackages = {"com.example.dao", "com.example.controller"},
        excludeFilters = @Filter(type = FilterType.ANNOTATION, classes = Repository.class)
    )
    
  3. 自定义过滤规则

    @ComponentScan(
        basePackages = "com.example",
        includeFilters = @Filter(type = FilterType.CUSTOM, classes = MyTypeFilter.class),
        useDefaultFilters = false
    )
    
  4. 多规则组合(Java 8+)

    @ComponentScan(value = "com.example", excludeFilters = {
        @Filter(type = FilterType.ANNOTATION, classes = Controller.class),
        @Filter(type = FilterType.ASPECTJ, pattern = "com.example.test.*")
    })
    

五、高级特性

  1. @ComponentScans
    若需同时配置多个 @ComponentScan(Java 8 以下使用):

    @ComponentScans({
        @ComponentScan("com.example.module1"),
        @ComponentScan("com.example.module2")
    })
    
  2. 与 Spring Boot 集成
    Spring Boot 的 @SpringBootApplication 已内置 @ComponentScan,默认扫描主类所在包及子包。

  3. 性能优化

    • 避免扫描过大的包范围(如 **),减少启动时间。

    • 使用 lazyInit 延迟非关键 Bean 的初始化。


六、常见问题与注意事项

  1. 未扫描到 Bean

    • 检查 basePackages 路径是否正确。

    • 确认 useDefaultFilters 是否为 true(默认启用)。

  2. 与 XML 配置冲突
    若同时使用 XML 和注解配置,需避免重复扫描同一包路径。

  3. 微服务场景
    在模块化项目中,每个模块可独立配置 @ComponentScan,实现组件隔离。


总结

@ComponentScan 是 Spring 自动化装配的核心注解,通过灵活配置包路径和过滤规则,极大简化了 Bean 的注册与管理。合理使用其高级特性(如自定义过滤、延迟加载),可提升大型项目的开发效率和运行时性能。


在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2371613.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

深入剖析 I/O 复用之 select 机制

深入剖析 I/O 复用之 select 机制 在网络编程中&#xff0c;I/O 复用是一项关键技术&#xff0c;它允许程序同时监控多个文件描述符的状态变化&#xff0c;从而高效地处理多个 I/O 操作。select 作为 I/O 复用的经典实现方式&#xff0c;在众多网络应用中扮演着重要角色。本文…

SpringBoot指定项目层日志记录

1、新建一个Springboot项目&#xff0c;添加Lombok依赖&#xff08;注意&#xff1a;这里使用的Lombok下的Slf4j快速日志记录方式&#xff09; <dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependenc…

RISC-V hardfault分析工具,RTTHREAD-RVBACKTRACE

RV BACKTRACE 简介 本文主要讲述RV BACKTRACE 的内部主要原理 没有接触过rvbacktrace可以看下面两篇文章&#xff0c;理解一下如何使用RVBACKTRACE RVBacktrace RISC-V极简栈回溯组件&#xff1a;https://club.rt-thread.org/ask/article/64bfe06feb7b3e29.html RVBacktra…

matlab 中function的用法

matlab 中function的用法 前言介绍1. 基本语法示例&#xff08;1&#xff09;可以直接输出&#xff08;2&#xff09;调用函数 2.输入参数和输出参数示例多输入参数和输出参数定义一个函数&#xff0c;计算两个数的和与差&#xff1a;调用该函数&#xff1a; 3. 默认参数示例 4…

解锁 LLM 推理速度:深入 FlashAttention 与 PagedAttention 的原理与实践

写在前面 大型语言模型 (LLM) 已经渗透到我们数字生活的方方面面,从智能问答、内容创作到代码辅助,其能力令人惊叹。然而,驱动这些强大模型的背后,是对计算资源(尤其是 GPU)的巨大需求。在模型推理 (Inference) 阶段,即模型实际对外提供服务的阶段,速度 (Latency) 和吞…

4个纯CSS自定义的简单而优雅的滚动条样式

今天发现 uni-app 项目的滚动条不显示&#xff0c;查了下原来是设置了 ::-webkit-scrollbar {display: none; } 那么怎么用 css 设置滚动条样式呢&#xff1f; 定义滚动条整体样式‌ ::-webkit-scrollbar 定义滚动条滑块样式 ::-webkit-scrollbar-thumb 定义滚动条轨道样式‌…

查看jdk是否安装并且配置成功?(Android studio安装前的准备)

WinR输入cmd打开命令提示窗口 输入命令 java -version 回车显示如下&#xff1a;

5月8日直播见!Atlassian Team‘25大会精华+AI实战分享

在刚刚落幕的 Atlassian Team’25 全球大会上&#xff0c;Atlassian发布了多项重磅创新&#xff0c;全面升级其协作平台&#xff0c;涵盖从Al驱动、知识管理到跨团队协作&#xff0c;再到战略执行的各个方面。 为帮助中国用户深入了解这些前沿动态&#xff0c;Atlassian全球白…

Windows系统下使用Kafka和Zookeeper,Python运行kafka(一)

下载和安装见Linux系统下使用Kafka和Zookeeper 配置 Zookeeper Zookeeper 是 Kafka 所依赖的分布式协调服务。在 Kafka 解压目录下,有一个 Zookeeper 的配置文件模板config/zookeeper.properties,你可以直接使用默认配置。 启动 Zookeeper 打开命令提示符(CMD),进入 K…

C++之“继承”

继续开始关于C相关的内容。C作为面向对象的语言&#xff0c;有三大特性&#xff1a;封装&#xff0c;继承&#xff0c;多态。 这篇文章我们开始学习&#xff1a;继承。 一、继承的概念和定义 1. 继承的概念 什么是继承呢&#xff1f; 字面意思理解来看&#xff1a;继承就是…

Webug4.0靶场通关笔记19- 第24关邮箱轰炸

目录 第24关 邮箱轰炸 1.配置环境 2.打开靶场 3.源码分析 4.邮箱轰炸 &#xff08;1&#xff09;注册界面bp抓包 &#xff08;2&#xff09;发送到intruder &#xff08;3&#xff09;配置position &#xff08;4&#xff09;配置payload &#xff08;5&#xff09;开…

java CompletableFuture 异步编程工具用法1

1、测试异步调用&#xff1a; static void testCompletableFuture1() throws ExecutionException, InterruptedException {// 1、无返回值的异步任务。异步线程执行RunnableCompletableFuture.runAsync(() -> System.out.println("only you"));// 2、有返回值的异…

若依框架Ruoyi-vue整合图表Echarts中国地图标注动态数据

若依框架Ruoyi-vue整合图表Echarts中国地图 概述创作灵感预期效果整合教程前期准备整合若依框架1、引入china.json2、方法3、data演示数据4、核心代码 完整代码[毫无保留]组件调用 总结 概述 首先&#xff0c;我需要回忆之前给出的回答&#xff0c;确保这次的内容不重复&#…

算法中的数学:约数

1.求一个整数的所有约数 对于一个整数x&#xff0c;他的其中一个约数若为i&#xff0c;那么x/i也是x的一个约数。而其中一个约数的大小一定小于等于根号x&#xff08;完全平方数则两个约数都为根号x&#xff09;&#xff0c;所以我们只需要遍历到根号x&#xff0c;然后计算出另…

[监控看板]Grafana+Prometheus+Exporter监控疑难排查

采用GrafanaPrometheusExporter监控MySQL时发现经常数据不即时同步&#xff0c;本示例也是本地搭建采用。 Prometheus面板 1&#xff0c;Detected a time difference of 11h 47m 22.337s between your browser and the server. You may see unexpected time-shifted query res…

LaTeX印刷体 字符与数学符号的总结

1. 希腊字母&#xff08;Greek Letters&#xff09; 名称小写 LaTeX大写 LaTeX显示效果Alpha\alphaAαα, AABeta\betaBββ, BBGamma\gamma\Gammaγγ, ΓΓDelta\delta\Deltaδδ, ΔΔTheta\theta\Thetaθθ, ΘΘPi\pi\Piππ, ΠΠSigma\sigma\Sigmaσσ, ΣΣOmega\omeg…

剥开 MP4 的 千层 “数字洋葱”:从外到内拆解通用媒体容器的核心

在当今数字化时代&#xff0c;MP4 格式随处可见&#xff0c;无论是在线视频、手机拍摄的短片&#xff0c;还是从各种渠道获取的音频视频文件&#xff0c;MP4 都占据着主流地位。它就像一个万能的 “数字媒体集装箱”&#xff0c;高效地整合和传输着各种视听内容。接下来&#x…

从彼得·蒂尔四象限看 Crypto「情绪变迁」:从密码朋克转向「标准化追求者」

作者&#xff1a;Techub 精选编译 撰文&#xff1a;Matti&#xff0c;Zee Prime Capital 编译&#xff1a;Yangz&#xff0c;Techub News 我又带着一篇受彼得蒂尔&#xff08;Peter Thiel&#xff09;启发的思想杂烩回来了。作为自封的「蒂尔学派」信徒&#xff0c;我常透过他…

Java线程安全问题深度解析与解决方案

一、线程安全问题的本质 并发编程的核心挑战&#xff1a;当多个线程同时访问共享资源时&#xff0c;由于操作系统的抢占式调度特性&#xff0c;可能导致不可预期的结果。这种因非原子操作和竞态条件引发的数据不一致问题&#xff0c;称为线程安全问题。 二、经典线程安全问题案…

Mybatis解决以某个字段存在,批量更新,不存在批量插入(高效)(一)

背景 在开发企业级应用时&#xff0c;我们经常需要处理批量数据的插入和更新操作。传统的逐条处理方式性能低下&#xff0c;而简单的REPLACE INTO或INSERT ... ON DUPLICATE KEY UPDATE在某些场景下又不够灵活。本文将介绍一种基于临时表的高效批量插入/更新方案&#xff0c;解…