基于注解方式操作Bean管理

本文详细介绍了Spring框架中注解的使用方法,包括创建对象、属性注入等,并演示了如何通过注解完成对象的创建及属性注入,最后还介绍了如何进行完全注解式的开发。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、什么是注解

  • 注解是代码特殊标记,格式:@注解名称(属性名称=属性值,属性名称=属性值…)
  • 使用注解,注解作用在类上面,方法上面,属性上面
  • 使用注解目的:简化xml配置

二、Spring针对Bean管理中创建对象提供注解

  • @Component
  • @Service
  • @Controller
  • @Repository

注意:上面四个注解的功能是相同的,都可以用来创建bean实例

三、注解方式实现对象创建

1.引入jar包aop

在这里插入图片描述

2.开启组件扫描

  • 首先引入context命名空间
<?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:p="http://www.springframework.org/schema/p"
       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.github"></context:component-scan>
  • 创建类,在上面添加注解
@Component
public class UserService {
    public void  add(){
        System.out.println("执行add方法");
    }
}

  • 编写测试方法
public class UserServiceTest {
    @Test
    public void test(){
        ApplicationContext context = new ClassPathXmlApplicationContext("beans3.xml");
        UserService service =  context.getBean("userService",UserService.class);
        service.add();
    }
}
  • 运行结果
    在这里插入图片描述
  • 修改注解为Service、Controller、Repository,再次运行
@Service
public class UserService {
    public void  add(){
        System.out.println("执行add方法");
    }
}

发现运行结果均相同

  • 结论:在对象的创建四个注解功能相同,但是我们习惯@Repository注解dao层,@Service注解service层,@Controller注解controller层

四、Spring针对Bean管理中属性注入提供注解

1.对象属性

  • @Autowired
  • @Qualifier
  • @Resource—javax提供,不是Spring原生

2.基本类型属性

  • @Value

五、注解方式实现属性注入

1. @Autowired:根据属性类型进行自动装配

  • 创建service和dao,在这俩类中添加创建对象注解
  • 在service注入dao对象,在service类添加dao类型属性,在属性上面使用注解
@Service
public class UserService {

    @Autowired
    private UserDao userDao;

    public void  add(){
        userDao.print();
        System.out.println("执行add方法");
    }
}

@Repository
public class UserDao {
    public void print(){
        System.out.println("dao 方法");
    }
}

2.@Qualifier:根据名称进行注入

  • 这个注解和Autowired一起使用
@Service
public class UserService {

    @Autowired
    @Qualifier(value = "userDao2")
    private UserDao userDao;

    public void  add(){
        userDao.print();
        System.out.println("执行add方法");
    }
}

3.@Resource:可以根据类型注入,也可以根据名称注入

@Service
public class UserService {

    @Resource(name = "userDao2")
    private UserDao userDao;

    public void  add(){
        userDao.print();
        System.out.println("执行add方法");
    }
}

4. @Value:注入普通类型属性

 @Value(value = "abc")
    private String name;

六、完全注解开发

  • 将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.github"></context:component-scan>
</beans>

import org.springframework.beans.factory.annotation.Configurable;
import org.springframework.context.annotation.ComponentScan;

@Configurable
@ComponentScan(value = "com.github")
public class SpringConfig {
}

  • 修改测试类
@Test
    public void test(){
        ApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class);
        UserService service =  context.getBean("userService",UserService.class);
        service.add();
    }

在这里插入图片描述
结论,得出的结果与配置文件是一样的,完全的去掉了配置文件

### Spring Boot 中使用注解方式装配 Bean 在 Spring 和 Spring Boot 应用程序中,`@Component`, `@Service`, `@Repository` 是常用的注解来自动检测并注册为 Spring 容器中的 Bean。这种方式简化了 XML 配置文件的编写工作量。 #### 使用 @Component 进行 Bean 自动扫描和注入 `@Component` 是一个泛型组件注解,适用于任何类型的 Spring 组件。当不知道某个类具体归属于哪一层时,可以使用此注解将其标记为 Spring 管理的对象[^3]。 ```java import org.springframework.stereotype.Component; @Component public class MyGenericComponent { public void doSomething() { System.out.println("Doing something..."); } } ``` #### 使用 @Service 注解服务层组件 对于业务逻辑实现的服务层接口或其实现类来说,推荐使用 `@Service` 来代替普通的 `@Component`。这有助于提高项目的语义清晰度,并使代码更易于理解和维护。 ```java import org.springframework.stereotype.Service; @Service public class UserService { public String getUserInfo(String userId) { return "User Info for ID:" + userId; } } ``` #### 使用 @Repository 处理数据访问对象 DAOs 为了标识持久化存储库(DAO),应该采用 `@Repository` 注解而不是简单的 `@Component` 或者其他替代品。这样做不仅能够增强代码结构上的意义表达,而且还能让框架识别到该实例是一个可能抛出特定异常的数据存取组件。 ```java import org.springframework.stereotype.Repository; @Repository public class UserRepository { private static final Map<String, User> users = new HashMap<>(); // 假设有一个初始化用户列表的过程... public List<User> findAllUsers() { return new ArrayList<>(users.values()); } } ``` 通过上述三种不同的注解,可以根据实际需求合理分配职责给各个层次的类,在保持良好分层架构的同时也方便后续扩展与调试操作。 一旦定义好了带有适当注解的类之后,只需要确保启动类上启用了组件扫描功能即可完成自动化配置过程: ```java @SpringBootApplication(scanBasePackages={"com.example"}) public class Application { public static void main(String[] args){ SpringApplication.run(Application.class,args); } } ``` 这样做的好处在于减少了显式的 XML 文件配置负担,提高了开发效率;同时也增强了系统的灵活性和可移植性[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值