博客
关于我
Spring的依赖注入
阅读量:459 次
发布时间:2019-03-06

本文共 1818 字,大约阅读时间需要 6 分钟。

依赖注入(Dependency Injection,简称DI)是Spring框架中实现控制反转(IoC)的核心机制,用于将应用程序的资源和配置信息注入到对象中,从而减少硬编码依赖,提高系统的灵活性和可维护性。以下是对依赖注入机制的详细解释,包括构造函数注入、set方法注入以及复杂类型注入的实践。

依赖注入的概念

依赖注入的核心思想是将对象的创建和管理交给Spring框架,而不是通过编码直接创建对象。这样一来,程序的设计变得更加灵活,模块之间的耦合度降低。尽管IoC解耦了对象之间的依赖关系,但依赖关系本身并未消失,仍然存在于程序中,只是由Spring框架来维护。

构造函数注入

构造函数注入是一种通过类的构造函数注入成员变量值的方式。在Spring配置文件中,使用

标签来指定构造函数的参数。

示例配置

在上述配置中,AccountServiceImpl类通过构造函数接收了三个参数:nameagebirthdaynameage使用value属性提供了具体的值,而birthday使用ref属性引用了now bean的对象。

set方法注入

set方法注入是一种更常用的注入方式,适用于需要经常修改的属性。类中需要提供对应的set方法,Spring会通过调用这些方法来注入值。

示例配置

在上述配置中,AccountServiceImpl2类中的setNamesetAgesetBirthday方法被Spring调用,分别注入了nameagebirthday属性的值。

复杂类型的注入

对于集合类型和映射类型的注入,Spring提供了丰富的标签,如

示例配置

AAA
BBB
CCC
AAA
BBB
CCC
AAA
BBB
CCC
BBB
ccc
ddd

在上述配置中,AccountServiceImpl3类中的集合属性myStrsmyListmySetmyMapmyProps通过对应的标签进行了注入。

注意事项

  • 引用循环处理:当一个对象需要注入另一个对象,而另一个对象又需要注入它时,可以使用@Autowired注解,并通过injectOnZeroEmbeddableBeans属性来解决。

  • 注入顺序:构造函数注入和set方法注入的顺序需要与类属性初始化顺序一致,否则可能导致值注入失败。

  • 类型匹配:在ref属性中注入对象时,目标对象必须已经被注册为Spring bean,否则会抛出类型匹配异常。

  • 通过以上方法,开发人员可以灵活地管理对象的依赖关系,提高系统的可维护性和灵活性。在实际应用中,建议结合构造函数注入和set方法注入,根据项目需求选择最合适的注入方式。

    转载地址:http://oqlfz.baihongyu.com/

    你可能感兴趣的文章
    MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
    查看>>
    MYSQL sql语句针对数据记录时间范围查询的效率对比
    查看>>
    mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
    查看>>
    mysql sysbench测试安装及命令
    查看>>
    mysql Timestamp时间隔了8小时
    查看>>
    Mysql tinyint(1)与tinyint(4)的区别
    查看>>
    MySQL Troubleshoting:Waiting on query cache mutex
    查看>>
    mysql union orderby 无效
    查看>>
    mysql v$session_Oracle 进程查看v$session
    查看>>
    mysql where中如何判断不为空
    查看>>
    MySQL Workbench 使用手册:从入门到精通
    查看>>
    MySQL Workbench 数据库建模详解:从设计到实践
    查看>>
    MySQL Workbench 数据建模全解析:从基础到实践
    查看>>
    mysql workbench6.3.5_MySQL Workbench
    查看>>
    MySQL Workbench安装教程以及菜单汉化
    查看>>
    MySQL Xtrabackup 安装、备份、恢复
    查看>>
    mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
    查看>>
    MySQL _ MySQL常用操作
    查看>>
    MySQL – 导出数据成csv
    查看>>
    MySQL —— 在CentOS9下安装MySQL
    查看>>