欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

Java中適配器模式是什么意思

這篇文章運(yùn)用簡(jiǎn)單易懂的例子給大家介紹Java中適配器模式是什么意思,代碼非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

創(chuàng)新互聯(lián)是一家以成都網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)、品牌設(shè)計(jì)、軟件運(yùn)維、網(wǎng)站推廣、小程序App開(kāi)發(fā)等移動(dòng)開(kāi)發(fā)為一體互聯(lián)網(wǎng)公司。已累計(jì)為成都工商代辦等眾行業(yè)中小客戶(hù)提供優(yōu)質(zhì)的互聯(lián)網(wǎng)建站和軟件開(kāi)發(fā)服務(wù)。

目的:把源類(lèi)型適配為目標(biāo)類(lèi)型,以適應(yīng)客戶(hù)端(Client)的需求;此處我們把目標(biāo)接口的調(diào)用方視為客戶(hù)端

使用場(chǎng)景:需要對(duì)類(lèi)型進(jìn)行由源類(lèi)型到目標(biāo)類(lèi)型轉(zhuǎn)換的場(chǎng)景中

前置條件已有客戶(hù)端

//Client 一個(gè)調(diào)用目標(biāo)接口的方法
Class ClientInvoking {

    static void invoke(TargetInterface target) {
        String value = target.getMark();
        System.out.println(value);
    }

}

常用的幾種模式

模式一:存在目標(biāo)接口,且存在已有方法

//目標(biāo)接口
public interface TargetInterface {
    
    public String getMark();

    public String getInfo();

}
//已有類(lèi)及方法
public class ExistClass {

    public String sayHello() {
        return "Hello";
    }
      
    public String sayWorld() {
        return "World";
    }
}

我們假設(shè)ExistClass返回的字符串正好是我們的客戶(hù)端需要用到的,但客戶(hù)端需要的是通過(guò)一個(gè)TargetInterface類(lèi)型的對(duì)象來(lái)獲取,因此我們需要想辦法對(duì)已有類(lèi)進(jìn)行適配,使其能夠滿(mǎn)足客戶(hù)端的需求;該模式下存在兩種應(yīng)用方案:

方案1.類(lèi)適配器模式

//適配器
public class ClassAdapter extends ExistClass implements TargetInterface {
    
    public int getMark() {
        String value = this.sayHello();
        return value;
    }
    
    public int getInfo() {
        String value = this.sayWorld();
        return value;
    }
    
}
//客戶(hù)端調(diào)用
TargetInterface target = new ClassAdapter();
ClientInvoking.invoke(target);

由Java接口的概念可知,ClassAdapter作為T(mén)argetInterface的實(shí)現(xiàn)類(lèi),能夠向上轉(zhuǎn)型為T(mén)argetInterface類(lèi)型,適應(yīng)了客戶(hù)端的需求。

方案2.對(duì)象適配器模式

//適配器
public class ClassAdapter implements TargetInterface {
    
    private ExistClass exist;
    
    public ClassAdapter(ExistClass existClass) {
        this.exist = existClass;
    }
    
    public int getMark() {
        String value = exist.sayHello();
        return value;
    }
    
    public int getInfo() {
        String value = exist.sayWorld();
        return value;
    }
    
}
//客戶(hù)端調(diào)用
TargetInterface target = new ClassAdapter(new ExistClass());
ClientInvoking.invoke(target);

該方案與類(lèi)適配器模式類(lèi)似,只是不采用繼承而采用持有對(duì)象的方式,更加靈活,擴(kuò)展性更強(qiáng)。

模式二:不存在目標(biāo)接口,但是存在目標(biāo)類(lèi),且存在已有方法

我們先對(duì)前置條件中的客戶(hù)端進(jìn)行改造,如下:

Class ClientInvoking {

    static void invoke(TargetClass target) {
        String value = target.getMark();
        System.out.println(value);
    }

}

改造后,invoke方法需要一個(gè)TargetClass類(lèi)的對(duì)象作為參數(shù);下面是目標(biāo)類(lèi)和已有類(lèi)

//目標(biāo)類(lèi)
public class Class {
    
    public String getMark() {
        return "yes";
    }

    public String getInfo() {
        return "no";
    }

}
//已有類(lèi)及方法
public class ExistClass {

    public String sayHello() {
        return "Hello";
    }
      
    public String sayWorld() {
        return "World";
    }
}

我們假設(shè)ExistClass返回的字符串正好是我們的客戶(hù)端需要用到的,且客戶(hù)端中需要的TargetClass對(duì)象的內(nèi)容已經(jīng)過(guò)時(shí),因此我們需要相辦法對(duì)ExistClass進(jìn)行適配,以適應(yīng)客戶(hù)端的需求;

//適配器
public class ClassAdapter extends TargetClass {
    
    private ExistClass exist;
    
    public ClassAdapter(ExistClass existClass) {
        this.exist = existClass;
    }
    
    public int getMark() {
        String value = exist.sayHello();
        return value;
    }
    
    public int getInfo() {
        String value = exist.sayWorld();
        return value;
    }
    
}
//客戶(hù)端調(diào)用
TargetClass target = new ClassAdapter(new ExistClass());
ClientInvoking.invoke(target);

在該種模式下,設(shè)計(jì)到兩個(gè)類(lèi),且最后要進(jìn)行向上轉(zhuǎn)型,根據(jù)Java的單繼承機(jī)制,我們只能通過(guò)持有對(duì)象的形式,即對(duì)象適配器模式。

模式三:缺省適配器模式

該模式中,不存在顯式的目標(biāo)類(lèi)型,而僅有源類(lèi)型;之所以需要用到這個(gè),往往是因?yàn)樵搭?lèi)型中提供了太多我們并不需要的東西,我們需要通過(guò)適配器模式進(jìn)行定制化。以WindowListener作為例子講解:

//WindowListener源碼
public interface WindowListener extends EventListener {
    public void windowOpened(WindowEvent e);
    public void windowClosing(WindowEvent e);
    public void windowClosed(WindowEvent e);
    ...
}
//添加監(jiān)聽(tīng)器的例子
Frame frame = new Frame();
frame.addWindowListener(new WindowListener() {
    @Override    
    public void windowOpened(WindowEvent e) {
            
    }

    @Override    
    public void windowClosing(WindowEvent e) {

    }

    @Override    
    public void windowClosed(WindowEvent e) {

    }
    ...
})

這樣的代碼,看起來(lái)很繁瑣;比如說(shuō)我只需要監(jiān)聽(tīng)正在關(guān)閉的事件,卻生成了許多與此無(wú)關(guān)的模板代碼,降低了代碼的可讀性,鑒于此,我們來(lái)做下定制,只監(jiān)聽(tīng)一個(gè)接口;

我們首先提供一個(gè)抽象類(lèi)實(shí)現(xiàn)了該接口,并為所有監(jiān)聽(tīng)器提供空實(shí)現(xiàn);然后再用抽象類(lèi)的子類(lèi)重寫(xiě)窗口正在關(guān)閉的監(jiān)聽(tīng)器的實(shí)現(xiàn),代碼如下:

//適配器
public abstract ListenerAdapter implements WindowListener {
    public void windowOpened(WindowEvent e) {}
    public void windowClosing(WindowEvent e) {}
    public void windowClosed(WindowEvent e) {}
    ...
}
//重寫(xiě)方法
public class OverrideWindowClosing extends ListenerAdapter {
    
    @Override    
    public void windowClosing(WindowEvent e) {        
       //TODO    
    }
    
}
//客戶(hù)端調(diào)用
frame.addWindowListener(new OverrideWindowClosing());

該方式簡(jiǎn)化了接口,提高了代碼可讀性。最重要的是,我們實(shí)現(xiàn)了對(duì)接口的定制,可以只做自己關(guān)心的事情。

關(guān)于Java中適配器模式是什么意思就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

文章題目:Java中適配器模式是什么意思
URL分享:http://www.chinadenli.net/article8/iiigip.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司企業(yè)建站網(wǎng)站制作網(wǎng)站改版網(wǎng)站營(yíng)銷(xiāo)網(wǎng)頁(yè)設(shè)計(jì)公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作