面試官:談談你對SpringAOP的瞭解?請加上這些內容,絕對加分!

一、引言

衆所周知,一旦提到AOP,相信大家都是條件反射的想到JDK代理和CGLib代理,沒錯,這兩個代理都是在運行時內存中臨時生成代理類,故而又稱作運行時增強——動態代理。世間萬物都不是絕對的,既然有動態代理,那麼,是否有想過:是不是存在靜態代理呢?

二、LTW(Load Time Weaving)

其實,除了運行時織入切面的方式外,我們還有一種途徑進行切面織入,它可以在類加載期通過字節碼轉換,進而將目標織入切入點(目標類),這種方式就是LTW,即靜態代理(靜待代理也被稱作編譯時增強,後面會有相關代碼樣例)。

LTW在Java5的時候就被引入了,想要了解其原理,先要了解一個知識——Instrument包。

三、java.lang.instrument包的工作原理

JDK5.0時引入了此包,目的就是爲了能對JVM底層組建進行訪問。如何訪問?其實說來個人覺得還挺麻煩的,就是需要通過JVM的啓動參數-javaagent在啓動時獲取JVM內部組件的引用。參數格式如下:

-javaagent:<jarpath>[=options]

此處先賣個關子,不急着解釋參數中的jarpath和options,後面的運行代碼及結果的樣例中會進行鍼對使用紅框標記說明,效果更好。

那麼,它和AOP有和關係呢?

因爲它在JVM啓動時會裝配並應用ClassTransformer,對類字節碼進行轉換,進而實現AOP的功能。

下面說一下instrument包下的兩個重要接口:

  • ClassFileTransformer

它是Class文件轉換器接口,這個接口有且僅有一個方法,如圖所示:

注意:transform方法會有一個返回值,類型是byte[],表示轉換後的字節碼,但是如果返回爲空,則表示不進行節碼轉換處理,千萬不要當作是把原先類的字節碼清空。

  • Instrumentation

這個接口提供了很多方法,我們主要注意一個方法即可,即:addTransformer方法,它的作用就是把一些ClassFileTransformer註冊到JVM內部,接口如圖所示:

具體工作原理是這樣的:

① ClassFileTransformer實例註冊到JVM之後,JVM在加載Class文件時,就會先調用ClassFileTransformer的transform()方法進行字節碼轉換;

② 若註冊了多個ClassFileTransformer實例,則按照註冊時的順序進行一次調用。

這樣也就實現了從JVM層面截獲字節碼,進而織入操作者自己希望添加的邏輯,即實現AOP效果。

四、代碼及演示效果

說了這麼多,來點乾貨,下面用代碼給大家演示一下如何向JVM中註冊轉換器實現AOP的。爲了方便大家閱讀,重要的說明筆者已經寫在代碼的註釋上或者圖片空白處,大家注意查看。

  • 首先,我們實現一個自己的轉換器,用於模擬需要切入的功能

注意,這裏再強調下,代碼中的return null;並不是將加載類的字節碼置空。

  • 其次,我們再實現一個代理類

爲什麼要實現代理類內,因爲不是動態代理呀。。。

  • 最後,我們寫一個主函數,代表程序入口

到此爲止,我們的Demo算是完成了,先來看一下運行的結果:

五、打jar的時候需要注意的地方

大家看到執行結果的截圖中,cmd界面下運行javaagent參數時指定了一個myTransformer.jar,這個jar是我們自己需要打出來的,可以直接使用eclipse具體步驟如下圖所示,注意圖中說明:

六、總結

大家可以看到,其實使用此類代理並沒有動態代理方便,甚至轉換器可能會對JVM所有類都產生影響,操作起來更新相對麻煩,實際生產部署時會有很多不便。

但是,寫這些是爲了讓大家更好、更多的去了解AOP,我們所熟知的AOP其實還有很多東西有待我們自身去學習和發現,其實Spring在"操作麻煩"這方面還是做了不少事的,提供了一些xml的配置化管理(此處就不再說了,因爲感覺一說又是一大長篇,有興趣的大家可以自己去看看,多瞭解寫東西總沒有壞處),很多情況下已經不需要再配置javaagent參數了。

最後提一句,如果在面試中提到了這些,相信面試官也會有加分吧。

精彩回顧

 程序員究竟能幹多少年?

 互聯網公司各崗位真實工作內容起底

 一次尷尬的採訪和程序員的傳奇腦洞!

 天一冷,程序員都穿上格子衫

 史上最真實的行業鄙視鏈曝光

 IT公司老闆落水,各部門員工怎麼救

 宿命之戰:程序員VS產品經理

 作爲一個前端,可以如何機智地弄壞一臺電腦?

 程序員跟產品經理打起來了,這是一個需求引發的血案...

 後端說,你個前端不會用 headers吧,我怒了!

 有個厲害的程序員女朋友是什麼體驗?

 多年來,程序員經常加班的真相終於揭開了…

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章