設(shè)計(jì)模式(3) 代理模式 動(dòng)態(tài)代理

根據(jù)上一個(gè)文章可輕松實(shí)現(xiàn)代理功能属韧,但是這樣做的代價(jià)是會(huì)生成許多的XxxProxy類亮钦,怎樣才能消除掉這些類呢掩完?這時(shí)我們可以使用JDK的動(dòng)態(tài)代理蟹地。

  • 使用JDK提供的動(dòng)態(tài)代理方案
    編寫(xiě)一個(gè)事務(wù)CarTimeHandler類 實(shí)現(xiàn)計(jì)時(shí)功能 、實(shí)現(xiàn)InvocationHandler接口
package cn.niriqiang.proxy;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;

/**
 * Created by fengyuwusong on 2017/8/19 15:37.
 */
public class CarTimeHandler implements InvocationHandler {
    //被代理的目標(biāo)對(duì)象
    private Object target;
    long start,end;
    public CarTimeHandler(Object target) {
        this.target = target;
    }


    private void before() {
        start=System.currentTimeMillis();
        System.out.println("開(kāi)車前時(shí)間:"+start);
    }

    private void after(){
        end=System.currentTimeMillis();
        System.out.println("開(kāi)車后時(shí)間:"+end+".\n總耗時(shí):"+(end-start)+"毫秒");
    }

    @Override
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        before();
        method.invoke(target);
        after();
        return null;
    }
}


再編寫(xiě)一個(gè)事務(wù)CarLogHandler類實(shí)現(xiàn)日志功能

package cn.niriqiang.proxy;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;

/**
 * Created by fengyuwusong on 2017/8/19 23:58.
 */
public class CarLogHandler implements InvocationHandler {
    ICar car;

    public CarLogHandler(ICar car) {
        this.car = car;
    }

    @Override
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        method.invoke(car);
        System.out.println("記錄日志");
        return null;
    }
}

則在main方法如此調(diào)用則可實(shí)現(xiàn)代理

package cn.niriqiang.proxy;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Proxy;

/**
 * Created by fengyuwusong on 2017/8/19 14:55.
 */
public class main {

    public static void main(String[] args) {
//        靜態(tài)代理
        //        ICar car=new CarImpl();
//        Carproxy carproxy=new Carproxy(car);
//        CarLogProxy carLogProxy=new CarLogProxy(carproxy);
//        carLogProxy.run();
//        動(dòng)態(tài)代理
        ICar car=new CarImpl();
        Class cls=car.getClass();
//        實(shí)現(xiàn)計(jì)時(shí)功能
        InvocationHandler carTimeHandler=new CarTimeHandler(car);
        car= (ICar) Proxy.newProxyInstance(cls.getClassLoader(),cls.getInterfaces(),carTimeHandler);
//        實(shí)現(xiàn)日志功能
        InvocationHandler carLogHandler=new CarLogHandler(car);
        car=(ICar)Proxy.newProxyInstance(cls.getClassLoader(),cls.getInterfaces(),carLogHandler);
        car.run();
    }
}

結(jié)果

開(kāi)車前時(shí)間:1503158582409
正在開(kāi)車~~~
開(kāi)車后時(shí)間:1503158583225.
總耗時(shí):816毫秒
記錄日志

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末藤为,一起剝皮案震驚了整個(gè)濱河市怪与,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌缅疟,老刑警劉巖分别,帶你破解...
    沈念sama閱讀 216,544評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異存淫,居然都是意外死亡耘斩,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén)桅咆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)括授,“玉大人,你說(shuō)我怎么就攤上這事岩饼〖孕椋” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,764評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵籍茧,是天一觀的道長(zhǎng)版述。 經(jīng)常有香客問(wèn)我,道長(zhǎng)寞冯,這世上最難降的妖魔是什么渴析? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,193評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮吮龄,結(jié)果婚禮上俭茧,老公的妹妹穿的比我還像新娘。我一直安慰自己漓帚,他們只是感情好母债,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,216評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著胰默,像睡著了一般场斑。 火紅的嫁衣襯著肌膚如雪漓踢。 梳的紋絲不亂的頭發(fā)上牵署,一...
    開(kāi)封第一講書(shū)人閱讀 51,182評(píng)論 1 299
  • 那天漏隐,我揣著相機(jī)與錄音,去河邊找鬼奴迅。 笑死青责,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的取具。 我是一名探鬼主播脖隶,決...
    沈念sama閱讀 40,063評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼暇检!你這毒婦竟也來(lái)了产阱?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 38,917評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤块仆,失蹤者是張志新(化名)和其女友劉穎构蹬,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體悔据,經(jīng)...
    沈念sama閱讀 45,329評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡庄敛,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,543評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了科汗。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片藻烤。...
    茶點(diǎn)故事閱讀 39,722評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖头滔,靈堂內(nèi)的尸體忽然破棺而出怖亭,到底是詐尸還是另有隱情,我是刑警寧澤坤检,帶...
    沈念sama閱讀 35,425評(píng)論 5 343
  • 正文 年R本政府宣布依许,位于F島的核電站,受9級(jí)特大地震影響缀蹄,放射性物質(zhì)發(fā)生泄漏峭跳。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,019評(píng)論 3 326
  • 文/蒙蒙 一缺前、第九天 我趴在偏房一處隱蔽的房頂上張望蛀醉。 院中可真熱鬧,春花似錦衅码、人聲如沸拯刁。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,671評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)垛玻。三九已至割捅,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間帚桩,已是汗流浹背亿驾。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,825評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留账嚎,地道東北人莫瞬。 一個(gè)月前我還...
    沈念sama閱讀 47,729評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像郭蕉,于是被迫代替她去往敵國(guó)和親疼邀。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,614評(píng)論 2 353

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