spring的@component注解的理解

1、@controller 控制器(注入服务)
2、@service 服务(注入dao)
3、@repository dao(实现dao访问)
4、@component (把普通pojo实例化到spring容器中,相当于配置文件中的<bean id="" class=""/>)

Spring 2.5 中除了提供 @Component 注释外,还定义了几个拥有特殊语义的注释,它们分别是:@Repository、@Service 和 @Controller。在目前的 Spring 版本中,这 3 个注释和 @Component 是等效的,但是从注释类的命名上,很容易看出这 3 个注释分别和持久层、业务层和控制层(Web 层)相对应。虽然目前这 3 个注释和 @Component 相比没有什么新意,但 Spring 将在以后的版本中为它们添加特殊的功能。所以,如果 Web 应用程序采用了经典的三层分层结构的话,最好在持久层、业务层和控制层分别采用 @Repository、@Service 和 @Controller 对分层中的类进行注释,而用 @Component 对那些比较中立的类进行注释。

在 一个稍大的项目中,通常会有上百个组件,如果这些组件采用xml的bean定义来配置,显然会增加配置文件的体积,查找以及维护起来也不太方便。 Spring2.5为我们引入了组件自动扫描机制,他可以在类路径底下寻找标注了 @Component,@Service,@Controller,@Repository注解的类,并把这些类纳入进spring容器中管理。它的作用 和在xml文件中使用bean节点配置组件时一样的。

 

今天在做项目时把一个既不是业务控制(Controller)、又不是业务逻辑(Service)、也不是数据访问(Dao)的类在不理解用注解@component的情况下注解成为Controller使用,结果肯定是有问题了,所以请教以后发现只用@component注解就完全可以解决了,所以在网上查阅了@component注解,特此记录一下,方便日后查阅。

1、@controller 控制器(注入服务)
用于标注控制层,相当于struts中的action层

2、@service 服务(注入dao)
用于标注服务层,主要用来进行业务的逻辑处理

3、@repository(实现dao访问)
用于标注数据访问层,也可以说用于标注数据访问组件,即DAO组件.

4、@component (把普通pojo实例化到spring容器中,相当于配置文件中的 
<bean id="" class=""/>
泛指各种组件,就是说当我们的类不属于各种归类的时候(不属于@Controller、@Services等的时候),我们就可以使用@Component来标注这个类。

说明: 
<context:component-scan base-package=”com.*”> 
上面的这个例子是引入Component组件的例子,其中base-package表示为需要扫描的所有子包。 
共同点:被@controller 、@service、@repository 、@component 注解的类,都会把这些类纳入进spring容器中进行管理

 

 

@Component注解的使用

@Component取代   或者  @Component(“id”) 取代配置文件applicationContext.xml:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans 
                           http://www.springframework.org/schema/beans/spring-beans.xsd
                           http://www.springframework.org/schema/context 
                           http://www.springframework.org/schema/context/spring-context.xsd">
    <!-- 组件扫描,扫描含有注解的类 -->
    <context:component-scan base-package="com.fly.spring.annotation"></context:component-scan>
</beans>

注解的类:

package com.fly.spring.annotation;

import org.springframework.stereotype.Component;

@Component("person")
public class Person {

    public void getString(){
        System.out.println("*********hello everyOne**********");
    }
}

测试的类:

package com.fly.spring.annotation;

import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class TestDemo {

    @Test
    public void demo(){
        String xmlpath = "com/fly/spring/annotation/applicationContext.xml";
        ApplicationContext context = new ClassPathXmlApplicationContext(xmlpath);
        Person bean = (Person) context.getBean("person");
        bean.getString();
    }
}

 

### 关于 Spring 中 `@Component` 注解的功能与使用 #### 功能概述 `@Component` 是 Spring 框架中的一个重要注解,主要用于将一个普通的 Java 类声明为 Spring 容器管理的一个组件。当某个类被标注为 `@Component` 后,Spring 的容器会通过组件扫描机制发现该类,并将其注册到 IoC(控制反转)容器中作为 Bean 实例进行管理[^4]。 此外,`@Component` 还是一个通用的注解,适用于多种场景下的组件定义。对于更加具体的应用场景,Spring 提供了一些基于 `@Component` 的衍生注解,比如 `@Repository`, `@Service`, 和 `@Controller`,它们分别对应数据访问层、业务逻辑层以及控制器层的具体用途[^3]。 --- #### 使用方法 为了使 `@Component` 能够正常工作,通常需要完成以下几个方面的配置: 1. **在目标类上添加 `@Component` 注解** 需要在希望由 Spring 管理的类上加上 `@Component` 注解。这样可以让 Spring 在启动时识别这些类并将其注册为 Bean。 2. **启用组件扫描** Spring 默认不会主动扫描项目中的所有类,因此需要显式地告诉 Spring 哪些包路径下的类应该被纳入扫描范围。这可以通过 XML 或者 Java 配置的方式实现: - 如果采用 XML 方式,则可以在 `<context:component-scan>` 标签中指定基础包名; - 如果采用 Java 配置方式,则可以利用 `@ComponentScan` 注解来设置扫描的基础包位置。 下面提供了一个简单的代码示例展示如何使用 `@Component` 注解: ```java // Step 1: 创建一个带有 @Component 注解的类 @Component public class MyComponent { public void displayMessage() { System.out.println("This is a component managed by Spring."); } } // Step 2: 配置 Spring 应用上下文以支持组件扫描 @Configuration @ComponentScan(basePackages = "com.example") // 扫描 com.example 包及其子包 public class AppConfig { } ``` 在此基础上,创建应用入口程序加载上述配置即可让 Spring 自动检测并初始化 `MyComponent` 对象。 --- #### 示例扩展 如果想要进一步模仿 Spring 行为或者优化扫描流程,还可以考虑引入一些高级工具类,例如 `ClassPathScanningCandidateComponentProvider` 来手动执行组件扫描操作;或者是借助 `AnnotationConfigApplicationContext` 加载基于注解形式的配置文件等等[^1]。 --- #### 总结说明 综上所述,`@Component` 不仅能够帮助开发者轻松构建轻量级模块化应用程序,而且配合其他特性还能极大提升开发效率和灵活性。更重要的是理解它背后的工作原理——即依赖注入与 AOP 技术相结合的设计模式[^2]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值