欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Spring 学习之路(六):Spring ioc 中的bean 注解

程序员文章站 2022-05-21 22:23:39
...

通过注解配置Spring中的bean

  • 组件扫描(component scanning): Spring 能够从 classpath 下自动扫描, 侦测和实例化具有特定注解的组件
  • 特定组件包括:

    1. @Component: 基本注解, 标识了一个受 Spring 管理的组件
    2. @Respository: 标识持久层组件
    3. @Service: 标识服务层(业务层)组件
    4. @Controller: 标识表现层组件
  • 对于扫描到的组件, Spring 有默认的命名策略: 使用非限定类名, 第一个字母小写. 也可以在注解中通过 value 属性值标识组件的名称

  • 接下来通过代码来演示spring中的组件扫描
- 定义特定注解的bean组件

@Component
public class User 

@Service
public class UserService 

@Repository("userDao")
public class UserDaoImpl implements UserDao

@Controller
public class UserController 

- beans-annotation.xml

    <!-- 指定ioc容器需要扫描的包 -->
    <!-- 可以通过resource-pattern 指定扫描的资源 -->
    <!-- 
    <context:component-scan base-package="com.zc.cris.beans.annotation"
        resource-pattern="userservice/*.class">

    </context:component-scan>
     -->

     <!-- context:exclude-filter 子节点指定排除哪些表达式的组件  -->
     <!-- context:include-filter 子节点指定只包含哪些表达式的组件,
            该子节点需要 use-default-filters 属性为false才可以生效 -->
     <context:component-scan base-package="com.zc.cris.beans.annotation" >

        <!-- 
        <context:exclude-filter type="annotation" 
        expression="org.springframework.stereotype.Repository"/>
         -->
         <!--   
         <context:include-filter type="annotation" 
         expression="org.springframework.stereotype.Repository"/>
         -->

        <!-- <context:include-filter type="assignable" expression="com.zc.cris.beans.annotation.userdao.UserDao"/> -->

        <context:exclude-filter type="assignable" expression="com.zc.cris.beans.annotation.userdao.UserDao"/>
     </context:component-scan>

- 测试代码:

    @Test
    void test() {
        ApplicationContext context = new ClassPathXmlApplicationContext("beans-annotation.xml");

        UserService userService= (UserService) context.getBean("userService");
        System.out.println(userService);
//      
//      UserDao userDao = (UserDao) context.getBean("userDao");
//      System.out.println(userDao);
//      
//      UserController userController = (UserController) context.getBean("userController");
//      System.out.println(userController);
//      
//      User user = (User) context.getBean("user");
//      System.out.println(user);
  • console的具体输出这里就不列出了,感兴趣的同学可以下载源代码试试

bean之间的依赖关系注解

  • 元素还会自动注册 AutowiredAnnotationBeanPostProcessor 实例, 该实例可以自动装配具有 @Autowired 和 @Resource 、@Inject注解的属性
  • 简单来说,就是以注解的方式向controller层的service属性注入service实现类,向service层的dao属性注入dao实现类,实例如下:
- controller层:

    @Autowired
    private UserService userService;

- service层:

    @Autowired
    public void setUserDao(@Qualifier("userDaoImpl") UserDao userDao) {
        this.userDao = userDao;
    }

- dao层

    @Autowired(required=false)
    private User user;
  • 关于 @Autowired 注解(@Autowired 注解自动装配具有兼容类型的单个 Bean属性):

    1. 构造器, 普通字段(即使是非 public), 一切具有参数的方法都可以应用@Authwired 注解

    2. 默认情况下, 所有使用 @Authwired 注解的属性都需要被设置. 当 Spring 找不到匹配的 Bean 装配属性时, 会抛出异常, 若某一属性允许不被设置, 可以设置 @Authwired 注解的 required 属性为 false

    3. 默认情况下, 当 IOC 容器里存在多个类型兼容的 Bean 时, 通过类型的自动装配将无法工作. 此时可以在 @Qualifier 注解里提供 Bean 的名称. Spring 允许对方法的入参标注 @Qualifiter 以指定注入 Bean 的名称(我们在后续的springMVC中可以经常看见这种形式)
    4. 以上代码完美解释了以关于 @Autowired 注解的三大特点,事实上我们开发的时候也是建议使用 @Autowired 注解,当然也可以使用 @Resource 或 @Inject 自动装配 Bean,只是功能没有 @Autowired 注解实现的那么好,具体的就不多介绍了

console:

Spring 学习之路(六):Spring ioc 中的bean 注解

相关标签: java spring