时间:2021-05-20
在做项目时,发现项目中 加载类时,有的地方使用@Autowired,有的地方使用@Resource
在网上搜集了资料
共同点
@Resource和@Autowired都可以作为注入属性的修饰,在接口仅有单一实现类时,两个注解的修饰效果相同,可以互相替换,不影响使用。
不同点
@Resource是Java自己的注解,@Resource有两个属性是比较重要的,分是name和type;Spring将@Resource注解的name属性解析为bean的名字,而type属性则解析为bean的类型。所以如果使用name属性,则使用byName的自动注入策略,而使用type属性时则使用byType自动注入策略。如果既不指定name也不指定type属性,这时将通过反射机制使用byName自动注入策略。
@Autowired是spring的注解,是spring2.5版本引入的,Autowired只根据type进行注入,不会去匹配name。如果涉及到type无法辨别注入对象时,那需要依赖@Qualifier或@Primary注解一起来修饰。
写列子
新建 HumanService.java类
package com.komiles.study.service;/** * @author komiles@163.com * @date 2020-03-23 11:46 */public interface HumanService { /** * 跑马拉松 * @return */ String runMarathon();}实现类 ManServiceImpl.java
package com.komiles.study.service.impl;import com.komiles.study.service.HumanService;import org.springframework.stereotype.Component;import org.springframework.stereotype.Service;/** * @author komiles@163.com * @date 2020-03-23 11:48 */@Servicepublic class ManServiceImpl implements HumanService { /** * 跑马拉松 */ @Override public String runMarathon() { return " A man run marathon"; }}新建HumanController.java
package com.komiles.study.controller;import com.komiles.study.service.HumanService;import com.komiles.study.service.impl.ManServiceImpl;import javax.annotation.Resource;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.beans.factory.annotation.Qualifier;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController;/** * @author komiles@163.com * @date 2020-03-23 11:49 */@RestController@RequestMapping("/human")public class HumanController { @Autowired private HumanService humanService; @GetMapping("/run") public String runMarathon() { return humanService.runMarathon(); }}运行程序
输出内容为: man run marathon
把controller里的 @Autowired 改成@Resource 也能正常访问。
假如我写多个实现类会怎么样呢?
新建一个 WomanServiceImpl.java
package com.komiles.study.service.impl;import com.komiles.study.service.HumanService;import org.springframework.context.annotation.Primary;import org.springframework.stereotype.Component;import org.springframework.stereotype.Service;/** * @author komiles@163.com * @date 2020-03-23 12:01 */@Servicepublic class WomanServiceImpl implements HumanService { /** * 跑马拉松 */ @Override public String runMarathon() { return "A Woman run marathon"; }}运行程序,发现报错了,因为有两个实现类,程序不知道找那个了
怎么办呢?
有两种办法
第一种,在实现类中给类起名字,在引入的时候直接引入名字。
例如:在ManServiceImpl.java类,@Service上加值。@Service(value = "manService") 或者 @Component(value = "manService")
package com.komiles.study.service.impl;import com.komiles.study.service.HumanService;import org.springframework.stereotype.Component;import org.springframework.stereotype.Service;/** * @author komiles@163.com * @date 2020-03-23 11:48 */@Service(value = "manService")//@Component(value = "manService")public class ManServiceImpl implements HumanService { /** * 跑马拉松 */ @Override public String runMarathon() { return " A man run marathon"; }}在Controller类中使用时,也需要制定一下名字。
如果使用@Resource 需要加上 @Resource(name="manService")
如果使用@Autowired 需要使用@Qualifier(value="manService")
package com.komiles.study.controller;import com.komiles.study.service.HumanService;import com.komiles.study.service.impl.ManServiceImpl;import javax.annotation.Resource;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.beans.factory.annotation.Qualifier;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController;/** * @author komiles@163.com * @date 2020-03-23 11:49 */@RestController@RequestMapping("/human")public class HumanController { @Autowired @Qualifier(value = "manService")// @Resource(name="manService") private HumanService humanService; @GetMapping("/run") public String runMarathon() { return humanService.runMarathon(); }}如果想优先引用某一个类,可以在实现类上使用 @Primary。
项目代码:
https://github.com/KoMiles/springboot/blob/master/src/main/java/com/komiles/study/controller/HumanController.java
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
目标了解HTTP请求/响应头及常见的属性;了解如何使用SpringBoot处理头信息;了解如何使用SpringBoot处理Cookie;学会如何对Session
前言:SpringBoot官网推荐使用HTML视图解析器,但是根据个人的具体业务也有可能使用到JSP视图解析器,所以这里我给大家简单介绍一下这两种视图解析器的具
详解springboot-修改内置tomcat版本1、解析SpringBoot父级依赖org.springframework.bootspring-boot-s
SpringBoot整合Gson整合Fastjson一、SpringBoot整合Gson1、pom依赖#在SpringBoot中给我们自带了json解析器,我们
今天说的则是使用另外一种扩展库lxml来对网页完成解析。同样的,lxml库能完成对html、xml格式的文件解析,并且能够用来解析大型的文档、解析速度也是相对比