博客
关于我
@Resource和@Autowired区别
阅读量:724 次
发布时间:2019-03-21

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

经过单元测试发现,在使用Spring注解时,若未在类字段上加上

@Autowired

注解,可能会导致用户对象无法被正确注入,出现。这让我对Spring的注解方式产生了更深的兴趣。

通过查阅资料,我了解到了Sprign的两个常见注解:@Resource和@Autowired。虽然它们都用于依赖注入,但两者在具体使用上存在显著差异。

@Resource注解的装配方式是按名称进行的,这意味着需要确保注入的目标对象属性名称与注解的值完全一致。而@Autowired注解则是基于类型进行装配,这种方法更加灵活且不易出错,因为只需要保证注入的对象类型与当前对象一致即可。

考虑到这些区别,当我们需要进行类型安全的注入时,@Autowired是一种更优选择。而@Resource注解则适合在已知注入单元名称的情况下使用,尤其是在经典的基于XML的配置文件中。

此外,在实际应用中,我们也需要结合具体的注解配置文件来判断选择哪种注解方式更加合适。不同的场景可能会有不同的最佳实践,例如在使用接口定义的时候,@Autowired可能会更加省力。无论哪种方式,最重要的是理解它们的原理,这样才能更好地进行对象的实例化和管理。

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

你可能感兴趣的文章
Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
查看>>
mysql InnoDB数据存储引擎 的B+树索引原理
查看>>
mysql innodb通过使用mvcc来实现可重复读
查看>>
mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
查看>>
Mysql join原理
查看>>
mysql order by多个字段排序
查看>>
MySQL Order By实现原理分析和Filesort优化
查看>>
mysql problems
查看>>
mysql replace first,MySQL中处理各种重复的一些方法
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
Mysql Row_Format 参数讲解
查看>>
mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
查看>>
MySQL Server 5.5安装记录
查看>>
mysql slave 停了_slave 停止。求解决方法
查看>>
MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
查看>>
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>
mysql union orderby 无效
查看>>
mysql where中如何判断不为空
查看>>