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

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

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

@Autowired

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

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

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

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

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

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

你可能感兴趣的文章
MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
查看>>
mysql8的安装与卸载
查看>>
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>
mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
查看>>
Mysqldump参数大全(参数来源于mysql5.5.19源码)
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>
mysqldump的一些用法
查看>>
mysqli
查看>>