Spring中的注解之@Override和@Autowired

一、Override

首先,@Override 注解是伪代码,表示子类重写父类的方法。这个注解不写也是可以的,但是写了有如下好处:

1. 可以当注释用,方便阅读(注解很重要的一个作用就是注释);

2. 编译器和 IDE 可以验证 @Override 下面的方法名是否是父类中所有的,如果没有的话就会报错。如果没有加 @Override ,而子类中的方法名又写错了,这个时候编译器是可以编译通过的,因为编译器以为这个方法是你的子类中自己增加的方法。

下面来验证一下,首先有一个 IPay 的父类,包含一个 toPay 方法,然后 WeChatPay 子类继承了 IPay 类,里面重写了父类的 toPay 方法。

public class WeChatPay extends IPay {
    @Override
    public void toPay() {
        System.out.println("开始微信支付");
    }

    public static void main(String[] args) {
        WeChatPay weChatPay = new WeChatPay();
        weChatPay.toPay();
    }
}

class IPay {
    public void toPay() {
        System.out.println("开始支付");
    }
}

我们来执行下 WeChatPay 中的 main 方法,输出内容如下:

开始微信支付

现在我们把父类中的 toPay 方法名改掉,可以看到代码还没执行,IDE 就有错误提示了:

如果执行上面的代码,编译器会直接报错,这是因为 toPay 方法在父类中不存在:

java: 方法不会覆盖或实现超类型的方法

这时候如果把 @Override 注解去掉,编译是可以通过的,编译器会认为是子类中定义了一个新方法:

二、Autowired

@Autowired 顾名思义,就是自动装配,其作用是为了消除代码Java代码里面的getter/setter与bean属性中的property。@Autowired 是 Spring 自带的注解,通过 AutowiredAnnotationBeanPostProcessor 类实现的依赖注入。

将@autowored写在被注入的成员变量上,就不用再xml文件中配置了,在程序中去掉相应的setter和getter方法

下面用代码测试一下:

interface IPay {
    String pay();
}

@Service
class Alipay implements IPay {
    @Override
    public String pay() {
        return "发起支付宝支付";
    }
}

@Service
public class PayService {
    @Autowired
    private Alipay alipay;

    public String toPay() {
        return alipay.pay();
    }
}

个人理解,@Autowired 就是自动装箱机制。Alipay 里面的 pay 是实例方法,如果想要调用它,就必须创建一个 alipay 对象,然后通过这个对象去调用。@Autowired 等效于下面的代码:

public class PayService {
    public String toPay() {
    	Alipay alipay = new Alipay();
        return alipay.pay();
    }
}

使用 @Autowired 注入,代码看起来简洁了很多

测试一下,如果把 @Autowired 注释掉看看会怎样:

哦吼,报错了!这说明 @Autowired 被注释掉之后, alipay 没有装箱,还只是一个初始值 null ,因此无法调用 pay 方法:

有几个地方需要注意下,@Autowired 必须用在 Spring bean 里面,也就是说类的外面必须要加 @Service@Component 等注解,让这个类变成 bean ,不然就会报错:

此外,如果是 SpringBoot 应用,@Controller@RestController 也是一个合法的 Spring bean:

@RestController
@RequestMapping("pay")
public class PayService {
    @Autowired
    private Alipay alipay;

    @GetMapping("alipay")
    public String toPay() {
        return alipay.pay();
    }
}

有 @RestController 就不用加 @Service 了

还有一个注意点,需要自动装配的类,本身也必须是 Spring bean,也就是说前面要加 @Service ,不然 @Autowired 无法注入。

现在代码可以正常运行,但是 @Autowired 还是有警告,如下图所示:

我们知道依赖注入有三种方式:

变量(filed)注入

@Autowired
private JavaMailSender mailSender;

构造方法注入

final JavaMailSender mailSender;
public IMailServiceImpl(JavaMailSender mailSender) {
    this.mailSender = mailSender;
}

set方法注入

private JavaMailSender mailSender;
@Autowired
public void setJavaMailSender  (JavaMailSender mailSender) {
    this.mailSender = mailSender;
}

其中第一种变量注入是不推荐的,原因可以看一下这篇文章: @Autowired(required=false)注入注意的问题

到此这篇关于Spring中的注解之@Override和@Autowired的文章就介绍到这了,更多相关注解@Override和@Autowired内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 详解Spring中的JavaConfig注解

    前言 大家都知道传统spring一般都是基于xml配置的,不过后来新增了许多JavaConfig的注解.特别是springboot,基本都是清一色的java config,不了解一下,还真是不适应.这里备注一下. @RestController spring4为了更方便的支持restfull应用的开发,新增了RestController的注解,比Controller注解多的功能就是给底下的RequestMapping方法默认都加上ResponseBody注解,省得自己再去每个去添加该注解. @C

  • Spring的@Validation和javax包下的@Valid区别以及自定义校验注解

    1.后台参数校验 Spring Validation验证框架对参数的验证机制提供了@Validated(Spring JSR-303规范,是标准JSR-303的一个变种),javax提供了@Valid(标准JSR-303规范),配合BindingResult可以直接提供参数验证结果 spring提供的验证:org.springframework.validation.annotation.Validated; javax提供的验证:javax.validation.Valid; 在检验Contr

  • 详解Java的Spring框架中的注解的用法

    1. 使用Spring注解来注入属性 1.1. 使用注解以前我们是怎样注入属性的 类的实现: class UserManagerImpl implements UserManager { private UserDao userDao; public void setUserDao(UserDao userDao) { this.userDao = userDao; } ... } 配置文件: <bean id="userManagerImpl" class="com.

  • Java之Spring注解配置bean实例代码解析

    前面几篇均是使用xml配置bean,如果有上百个bean,这是不可想象的.故而,请使用注解配置bean !!! [1]注解类别 @Component : 基本注解, 标识了一个受 Spring(点击这里可以下载<Spring应用开发完全手册>) 管理的组件 @Repository : 标识持久层组件 @Service : 标识服务层(业务层)组件 @Controller : 标识表现层组件 Spring 能够从 classpath 下自动扫描, 侦测和实例化具有特定注解的组件. 对于扫描到的组

  • java基于spring注解AOP的异常处理的方法

    一.前言 项目刚刚开发的时候,并没有做好充足的准备.开发到一定程度的时候才会想到还有一些问题没有解决.就比如今天我要说的一个问题:异常的处理.写程序的时候一般都会通过try...catch...finally对异常进行处理,但是我们真的能在写程序的时候处理掉所有可能发生的异常吗? 以及发生异常的时候执行什么逻辑,返回什么提示信息,跳转到什么页面,这些都是要考虑到的. 二.基于@ControllerAdvice(加强的控制器)的异常处理 @ControllerAdvice注解内部使用@Except

  • spring mvc常用注解_动力节点Java学院整理

    Spring从2.5版本开始在编程中引入注解,用户可以使用@RequestMapping, @RequestParam, @ModelAttribute等等这样类似的注解.到目前为止,Spring的版本虽然发生了很大的变化,但注解的特性却是一直延续下来,并不断扩展,让广大的开发人员的双手变的更轻松起来,这都离不开Annotation的强大作用,今天我们就一起来看看Spring MVC 4中常用的那些注解吧. 1. @Controller Controller控制器是通过服务接口定义的提供访问应用

  • Java注解机制之Spring自动装配实现原理详解

    Java中使用注解的情况主要在SpringMVC(Spring Boot等),注解实际上相当于一种标记语言,它允许你在运行时动态地对拥有该标记的成员进行操作.注意:spring框架默认不支持自动装配的,要想使用自动装配需要修改spring配置文件中<bean>标签的autowire属性. 自动装配属性有6个值可选,分别代表不同的含义: byName ->从Spring环境中获取目标对象时,目标对象中的属性会根据名称在整个Spring环境中查找<bean>标签的id属性值.如果

  • java SpringBoot自定义注解,及自定义解析器实现对象自动注入操作

    # java-SpringBoot自定义参数解析器实现对象自动注入 解析器逻辑流程图表 后台解析注解的解析器 首先,我在java后台编写了一个解析器,代码如下 import com.ruoyi.framework.interceptor.annotation.LoginUser; import com.ruoyi.project.WebMoudle.WebUser.domain.WebUser; import com.ruoyi.project.WebMoudle.WebUser.service

  • 使用Java注解模拟spring ioc容器过程解析

    使用注解,简单模拟spring ioc容器.通过注解给对象属性注入值. 项目结构 annotation 包,用于存放自定义注解 Component 注解表示该类为组件类,并需要声明名字 package priv.haidnor.annotation; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy;

  • 详解spring 配置的两种方式:JAVA配置和注解配置

    众所周知,spring自从3.0开始以后,就全面推荐使用配置的方式进行代码编写了,这种方式确实可以避免了之前一个项目里面一大堆XML的情况,毕竟XML的可读性实在不怎么样,而且一会写JAVA,一会写XML,确实还是蛮麻烦的 就目前来说spring的配置方式一般为两种:JAVA配置和注解配置.那么什么的是注解配置呢?什么是JAVA配置呢? //注解配置: @Service @Component @Repository @Controlle //JAVA配置 @Confirguration 相当于s

随机推荐