Spring中的注解之@Override和@Autowired
一、Override
首先,@Override
注解是偽代碼,表示子類重寫父類的方法。這個注解不寫也是可以的,但是寫了有如下好處:
1. 可以當(dāng)注釋用,方便閱讀(注解很重要的一個作用就是注釋);
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("開始支付"); } }
我們來執(zhí)行下 WeChatPay
中的 main
方法,輸出內(nèi)容如下:
開始微信支付
現(xiàn)在我們把父類中的 toPay
方法名改掉,可以看到代碼還沒執(zhí)行,IDE 就有錯誤提示了:
如果執(zhí)行上面的代碼,編譯器會直接報錯,這是因為 toPay
方法在父類中不存在:
java: 方法不會覆蓋或?qū)崿F(xiàn)超類型的方法
這時候如果把 @Override
注解去掉,編譯是可以通過的,編譯器會認為是子類中定義了一個新方法:
二、Autowired
@Autowired
顧名思義,就是自動裝配,其作用是為了消除代碼Java代碼里面的getter/setter與bean屬性中的property。@Autowired
是 Spring 自帶的注解,通過 AutowiredAnnotationBeanPostProcessor
類實現(xiàn)的依賴注入。
將@autowored寫在被注入的成員變量上,就不用再xml文件中配置了,在程序中去掉相應(yīng)的setter和getter方法
下面用代碼測試一下:
interface IPay { String pay(); } @Service class Alipay implements IPay { @Override public String pay() { return "發(fā)起支付寶支付"; } } @Service public class PayService { @Autowired private Alipay alipay; public String toPay() { return alipay.pay(); } }
個人理解,@Autowired
就是自動裝箱機制。Alipay
里面的 pay
是實例方法,如果想要調(diào)用它,就必須創(chuàng)建一個 alipay
對象,然后通過這個對象去調(diào)用。@Autowired
等效于下面的代碼:
public class PayService { public String toPay() { Alipay alipay = new Alipay(); return alipay.pay(); } }
使用
@Autowired
注入,代碼看起來簡潔了很多
測試一下,如果把 @Autowired
注釋掉看看會怎樣:
哦吼,報錯了!這說明 @Autowired
被注釋掉之后, alipay
沒有裝箱,還只是一個初始值 null
,因此無法調(diào)用 pay
方法:
有幾個地方需要注意下,@Autowired
必須用在 Spring bean 里面,也就是說類的外面必須要加 @Service
、@Component
等注解,讓這個類變成 bean ,不然就會報錯:
此外,如果是 SpringBoot 應(yīng)用,@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
無法注入。
現(xiàn)在代碼可以正常運行,但是 @Autowired
還是有警告,如下圖所示:
我們知道依賴注入有三種方式:
變量(filed)注入
@Autowired private JavaMailSender mailSender;
構(gòu)造方法注入
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)注入注意的問題
到此這篇關(guān)于Spring中的注解之@Override和@Autowired的文章就介紹到這了,更多相關(guān)注解@Override和@Autowired內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java Socket編程筆記_動力節(jié)點Java學(xué)院整理
Socket對于我們來說就非常實用了。下面是本次學(xué)習(xí)的筆記。主要分異常類型、交互原理、Socket、ServerSocket、多線程這幾個方面闡述2017-05-05MyBatis-Plus 如何實現(xiàn)連表查詢的示例代碼
這篇文章主要介紹了MyBatis-Plus 如何實現(xiàn)連表查詢的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08Java ThreadLocal詳解_動力節(jié)點Java學(xué)院整理
ThreadLocal,很多地方叫做線程本地變量,也有些地方叫做線程本地存儲,本文會詳細的介紹一下,有興趣的可以了解一下2017-06-06Java使用wait和notify實現(xiàn)線程之間的通信
Java 線程通信是將多個獨立的線程個體進行關(guān)聯(lián)處理,使得線程與線程之間能進行相互通信,下面這篇文章主要給大家介紹了關(guān)于Java使用wait和notify實現(xiàn)線程之間通信的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下2022-04-04SpringBoot Redis實現(xiàn)接口冪等性校驗方法詳細講解
這篇文章主要介紹了SpringBoot Redis實現(xiàn)接口冪等性校驗方法,近期一個老項目出現(xiàn)了接口冪等性校驗問題,前端加了按鈕置灰,依然被人拉著接口參數(shù)一頓輸出,還是重復(fù)調(diào)用了接口,通過復(fù)制粘貼,完成了后端接口冪等性調(diào)用校驗2022-11-11沒有編輯器的環(huán)境下是如何創(chuàng)建Servlet(Tomcat+Java)項目的?
今天給大家?guī)淼氖顷P(guān)于Java的相關(guān)知識,文章圍繞著在沒有編輯器的環(huán)境下如何創(chuàng)建Servlet(Tomcat+Java)項目展開,文中有非常詳細的介紹及代碼示例,需要的朋友可以參考下2021-06-06Java 中POI 導(dǎo)入EXCEL2003 和EXCEL2007的實現(xiàn)方法
這篇文章主要介紹了Java 中POI 導(dǎo)入EXCEL2003 和EXCEL2007的實現(xiàn)方法的相關(guān)資料,希望通過本文大家能掌握理解這種方法,需要的朋友可以參考下2017-09-09