Gointerface接口声明实现及作用详解
564
2022-09-17
使用@Autowired注解有错误提示的解决
目录使用@Autowired注解有错误提示处理方式@Resource注解与@Autowired注解的异同点Spring的@Autowired注解报错改为警告
使用@Autowired注解有错误提示
使用Spring boot +mybatis框架时,在service实现类中使用Mapper类,给Mapper类添加@Autowired注解时发现
有错误提示:could not autowire,no beans of "XXX" type found
但程序的编译和运行都正常。
处理方式
方案一:@Autowired(required = false) 设置required 属性值为 false,错误消失
方案二:用@Resource注解替换@Autowired注解,错误消失
@Resource注解与@Autowired注解的异同点
这两个注解都是用作bean的注入时使用,都是为一个对象变量省去写get,set方法,自动为这个对象注入实例化对象(即注入依赖)注入的方式还是有所区别的 :
@Autowired是基于spring的注解org.springframework.beans.factory.annotation.Ahttp://utowired,它默认是按类型进行的装配的,如果想要它按名字进行装配则需在@autowired下面添加@qualifier("name")`注解,都无法找到唯一的一个实现类的时候报错。@Autowired注解默认情况下必须要求依赖对象必须存在,如果要允许nulAAzyLl值,则应该设置它的required属性为false,
@Resource是基于j2ee的注解(可以减少了与spring的耦合),(JDK1.6以上支持)默认是按名字进行注解,若不指定装配bean的名字,当注解写在字段上时,默认取字段名,按照名称查找http://通过set方法进行装配,倘若有多个子类,则会报错。需要注意的是name属性一旦指定,就只会按照名称进行装配
Spring的@Autowired注解报错改为警告
使用@Autowired注解在idea里会有error提示,不影响程序正常运行,据我观察身边同事们大多也是选择无视这个error,但一条红线放在这看着确实难受。后来得知可以把这里的error改为warning,并且不会干扰其他代码。
打开idea的settings,找到如下图所示位置,修改自动注入时的error错误为warning警告。
成功修改后就不会有烦人的红色下划线了(变成了黄色的),不建议随意修改这些检测,除非你确实很了解它。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~