AOP之Aspectj HelloWorld

一、環(huán)境準(zhǔn)備
本案例使用的JDK版本是JDK1.8

二、步驟
1唉匾、新建項(xiàng)目


圖片.png

2、輸入項(xiàng)目名稱


輸入項(xiàng)目名稱.png

3匠楚、生成項(xiàng)目


生成項(xiàng)目.jpg

4巍膘、加入maven框架支持
加入maven框架支持.jpg

5、加入aspectj的maven依賴和maven的aspectj的編譯支持插件

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>groupId</groupId>
    <artifactId>aspectj-helloworld</artifactId>
    <version>1.0-SNAPSHOT</version>

    <dependencies>
        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjweaver</artifactId>
            <version>1.9.2</version>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.codehaus.mojo</groupId>
                <artifactId>aspectj-maven-plugin</artifactId>
                <version>1.5</version>
                <configuration>
                    <complianceLevel>1.7</complianceLevel>
                    <includes>
                        <include>**/*.java</include>
                        <include>**/*.aj</include>
                    </includes>
                    <aspectDirectory>src/main/java/aspectj</aspectDirectory>
                    <XaddSerialVersionUID>true</XaddSerialVersionUID>
                    <showWeaveInfo>true</showWeaveInfo>
                </configuration>
                <executions>
                    <execution>
                        <id>compile_with_aspectj</id>
                        <goals>
                            <goal>compile</goal>
                        </goals>
                    </execution>
                    <execution>
                        <id>test-compile_with_aspectj</id>
                        <goals>
                            <goal>test-compile</goal>
                        </goals>
                    </execution>
                </executions>
                <dependencies>
                    <dependency>
                        <groupId>org.aspectj</groupId>
                        <artifactId>aspectjtools</artifactId>
                        <version>1.8.5</version>
                    </dependency>
                </dependencies>
            </plugin>
        </plugins>
    </build>
</project>

6芋簿、新建com.lin.aspectj.HelloAsectj.aj文件

package com.lin.aspectj;

public aspect HelloAspect {

    pointcut HelloWorldPointCut() : execution(* com.lin.aspectj.*.*(..));

    Object around():HelloAspect.HelloWorldPointCut(){
        System.out.println("asp");
        proceed();
        return new Object();
    }
}

7峡懈、新建com.lin.aspectj.Hello類

package com.lin.aspectj;

public class Hello {
    public void test(){
        System.out.println("hello world");
    }

    public static void main(String[] args) {
        new Hello().test();
    }
}

8、運(yùn)行Hello類中的main方法,結(jié)果如下:

/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/bin/java -Dfile.encoding=UTF-8 -classpath /Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/charsets.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/deploy.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/ext/cldrdata.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/ext/dnsns.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/ext/jaccess.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/ext/jfxrt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/ext/localedata.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/ext/nashorn.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/ext/sunec.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/ext/sunjce_provider.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/ext/sunpkcs11.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/ext/zipfs.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/javaws.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/jce.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/jfr.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/jfxswt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/jsse.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/management-agent.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/plugin.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/resources.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/jre/lib/rt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/lib/ant-javafx.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/lib/dt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/lib/javafx-mx.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/lib/jconsole.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/lib/packager.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/lib/sa-jdi.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/lib/tools.jar:/Users/xmly/workspace/java/aspectj-helloworld/target/classes:/Users/xmly/workspace/repository/org/aspectj/aspectjweaver/1.9.2/aspectjweaver-1.9.2.jar com.lin.aspectj.Hello
asp
asp
hello world

Process finished with exit code 0

9与斤、該項(xiàng)目的總體結(jié)構(gòu)如下圖所示:


全局.png

10肪康、該demo項(xiàng)目已放在github上荚恶,有需要的同學(xué)可以上去下載
https://github.com/lwbkfc/aspectj-helloworld

11、提問:有同學(xué)能解釋一下為什么asp打印了兩次嗎磷支?

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末谒撼,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子雾狈,更是在濱河造成了極大的恐慌廓潜,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,104評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件箍邮,死亡現(xiàn)場離奇詭異,居然都是意外死亡叨叙,警方通過查閱死者的電腦和手機(jī)锭弊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來擂错,“玉大人味滞,你說我怎么就攤上這事∨パ剑” “怎么了剑鞍?”我有些...
    開封第一講書人閱讀 168,697評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長爽醋。 經(jīng)常有香客問我蚁署,道長,這世上最難降的妖魔是什么蚂四? 我笑而不...
    開封第一講書人閱讀 59,836評論 1 298
  • 正文 為了忘掉前任光戈,我火速辦了婚禮,結(jié)果婚禮上遂赠,老公的妹妹穿的比我還像新娘久妆。我一直安慰自己,他們只是感情好跷睦,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,851評論 6 397
  • 文/花漫 我一把揭開白布筷弦。 她就那樣靜靜地躺著,像睡著了一般抑诸。 火紅的嫁衣襯著肌膚如雪烂琴。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,441評論 1 310
  • 那天蜕乡,我揣著相機(jī)與錄音监右,去河邊找鬼。 笑死异希,一個胖子當(dāng)著我的面吹牛健盒,可吹牛的內(nèi)容都是我干的绒瘦。 我是一名探鬼主播,決...
    沈念sama閱讀 40,992評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼扣癣,長吁一口氣:“原來是場噩夢啊……” “哼惰帽!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起父虑,我...
    開封第一講書人閱讀 39,899評論 0 276
  • 序言:老撾萬榮一對情侶失蹤该酗,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后士嚎,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體呜魄,經(jīng)...
    沈念sama閱讀 46,457評論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,529評論 3 341
  • 正文 我和宋清朗相戀三年莱衩,在試婚紗的時候發(fā)現(xiàn)自己被綠了爵嗅。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,664評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡笨蚁,死狀恐怖睹晒,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情括细,我是刑警寧澤伪很,帶...
    沈念sama閱讀 36,346評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站奋单,受9級特大地震影響锉试,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜览濒,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,025評論 3 334
  • 文/蒙蒙 一键痛、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧匾七,春花似錦絮短、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,511評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至邑贴,卻和暖如春席里,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背拢驾。 一陣腳步聲響...
    開封第一講書人閱讀 33,611評論 1 272
  • 我被黑心中介騙來泰國打工奖磁, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人繁疤。 一個月前我還...
    沈念sama閱讀 49,081評論 3 377
  • 正文 我出身青樓咖为,卻偏偏與公主長得像秕狰,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子躁染,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,675評論 2 359

推薦閱讀更多精彩內(nèi)容

  • 用兩張圖告訴你鸣哀,為什么你的 App 會卡頓? - Android - 掘金 Cover 有什么料? 從這篇文章中你...
    hw1212閱讀 12,745評論 2 59
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,304評論 25 707
  • 當(dāng)其他人在販賣焦慮時吞彤,我在悄悄努力我衬。當(dāng)其他人醒悟過來了,我已經(jīng)前進(jìn)了一大截饰恕。當(dāng)別人都羨慕我時挠羔,我已經(jīng)做到寵辱不驚了...
    墨染軒然閱讀 115評論 0 1
  • 文/牧野笑 張三豐教張無忌太極劍,先是慢吞吞演將了一遍埋嵌,然后問他破加,都記住了沒有?張無忌說莉恼,已經(jīng)忘了一小半拌喉。張三豐重...
    牧野笑閱讀 1,008評論 0 1