国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Java設計模式之(六)——橋接模式

番茄西紅柿 / 3059人閱讀

摘要:橋接模式定義橋接模式定義抽象化角色它的主要職責是定義出該角色的行為,同時保存一個對實現化角色的引用,該角色一般是抽象類。這種優雅的實現數據庫切換方式就是利用了橋接模式。

1、什么是橋接模式?

Decouple an abstraction from its implementation so that the two can vary independently.

橋接模式(Bridge Pattern):將抽象和實現解耦, 使得兩者可以獨立地變化。

另外一種解釋是:一個類存在兩個(或多個)獨立變化的維度,我們通過組合的方式,讓這兩個(或多個)維度可以獨立進行擴展。

聽起來可能還是很深奧,沒關系,下面通過例子講解。

2、橋接模式定義

image-20210908222425355

①、Abstraction

抽象化角色:它的主要職責是定義出該角色的行為, 同時保存一個對實現化角色的引用, 該角色一般是抽象類。

②、Implementor

實現化角色:它是接口或者抽象類, 定義角色必需的行為和屬性。

③、RefinedAbstraction

修正抽象化角色:它引用實現化角色對抽象化角色進行修正。

④、ConcreteImplementor

具體實現化角色:它實現接口或抽象類定義的方法和屬性。

3、橋接模式通用代碼實現

實現化類:

public interface Implementor {    void doSomething();}

具體實現化類:

public class ConcreteImplementor1 implements Implementor{    @Override    public void doSomething() {        // 具體業務邏輯處理    }}
public class ConcreteImplementor2 implements Implementor{    @Override    public void doSomething() {        // 具體業務邏輯    }}

這里定義了兩個,可能有多個。

抽象化角色:

public abstract class Abstraction {    // 定義對實現化角色的引用    private Implementor implementor;    public Abstraction(Implementor implementor){        this.implementor = implementor;    }    // 自身的行為和屬性    public void request(){        this.implementor.doSomething();    }    // 獲取實現化角色    public Implementor getImplementor(){        return implementor;    }}

修正抽象化角色:

public class RefinedAbstraction extends  Abstraction{    // 覆寫構造函數    public RefinedAbstraction(Implementor implementor){        super(implementor);    }    // 修正父類的行為    @Override    public void request() {        super.request();    }}

測試:

public class BridgeClient {    public static void main(String[] args) {        // 定義一個實現化角色        Implementor implementor = new ConcreteImplementor1();        // 定義一個抽象化角色        Abstraction abstraction = new RefinedAbstraction(implementor);        // 執行方法        abstraction.request();    }}

如果我們的實現化角色有很多的子接口, 然后是一堆的子實現。 在構造函數中傳遞一個明確的實現者, 代碼也是很清晰的。

4、橋接模式經典例子—JDBC

我們在剛開始用 JDBC 直連數據庫的時候,會有這樣一段代碼:

Class.forName("com.mysql.cj.jdbc.Driver");//加載及注冊JDBC驅動程序String url = "jdbc:mysql://localhost:3306/sample_db?user=root&password=your_password";Connection con = DriverManager.getConnection(url);Statement stmt = con.createStatement();String query = "select * from test";ResultSet rs=stmt.executeQuery(query);while(rs.next()) {  rs.getString(1);  rs.getInt(2);}

如果我們想要把 MySQL 數據庫換成 Oracle 數據庫,只需要把第一行代碼中的 com.mysql.cj.jdbc.Driver 換成oracle.jdbc.driver.OracleDriver 就可以了。

這種優雅的實現數據庫切換方式就是利用了橋接模式。

我們首先看 Driver 類:

package com.mysql.cj.jdbc;import java.sql.DriverManager;import java.sql.SQLException;public class Driver extends NonRegisteringDriver implements java.sql.Driver {    public Driver() throws SQLException {    }    static {        try {            DriverManager.registerDriver(new Driver());        } catch (SQLException var1) {            throw new RuntimeException("Cant register driver!");        }    }}

這段代碼 Class.forName("com.mysql.cj.jdbc.Driver") 作用有兩個:

①、要求 JVM 查找并加載指定的 Driver 類。

②、執行該類的靜態代碼,也就是將 MySQL Driver 注冊到 DriverManager 類中。

接著我們看 DriverManager 類:

public class DriverManager {  private final static CopyOnWriteArrayList registeredDrivers = new CopyOnWriteArrayList();  //...  static {    loadInitialDrivers();    println("JDBC DriverManager initialized");  }  //...  public static synchronized void registerDriver(java.sql.Driver driver) throws SQLException {    if (driver != null) {      registeredDrivers.addIfAbsent(new DriverInfo(driver));    } else {      throw new NullPointerException();    }  }  public static Connection getConnection(String url, String user, String password) throws SQLException {    java.util.Properties info = new java.util.Properties();    if (user != null) {      info.put("user", user);    }    if (password != null) {      info.put("password", password);    }    return (getConnection(url, info, Reflection.getCallerClass()));  }  //...}

當我們把具體的 Driver 實現類(比如,com.mysql.cj.jdbc.Driver)注冊到 DriverManager 之后,后續所有對 JDBC 接口的調用,都會委派到對具體的 Driver 實現類來執行。而 Driver 實現類都實現了相同的接口(java.sql.Driver ),這也是可以靈活切換 Driver 的原因。

image-20210908233556259

5、橋接模式優點

①、抽象和實現分離

這也是橋梁模式的主要特點, 它完全是為了解決繼承的缺點而提出的設計模式。 在該模式下, 實現可以不受抽象的約束, 不用再綁定在一個固定的抽象層次上。

②、優秀的擴充能力

看看我們的例子, 想增加實現? 沒問題! 想增加抽象, 也沒有問題! 只要對外暴露的接口層允許這樣的變化, 我們已經把變化的可能性減到最小。

③、實現細節對客戶透明

客戶不用關心細節的實現, 它已經由抽象層通過聚合關系完成了封裝。

6、橋接模式應用場景

①、如果一個系統需要在構件的抽象化角色和具體化角色之間增加更多的靈活性,避免在兩個層次之間建立靜態的繼承聯系,通過橋接模式可以使它們在抽象層建立一個關聯關系。

②、對于那些不希望使用繼承或因為多層次繼承導致系統類的個數急劇增加的系統,橋接模式尤為適用。

③、一個類存在兩個獨立變化的維度,且這兩個維度都需要進行擴展。

作者:IT可樂

資源:微信搜【IT可樂】關注我,回復 【電子書】有我特別篩選的免費電子書。
本文版權歸作者所有,歡迎轉載,但未經作者同意不能轉載,否則保留追究法律責任的權利。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/124537.html

相關文章

  • JavaScript設計模式系列橋接模式

    摘要:橋接模式橋接是用于把抽象化與現實化解耦,使得二者可以獨立變化,這種類型的設計模式屬于結構型模式,它通過提供抽象化和現實化之間的橋接結構,實現二者的解耦。所以接口和實現是可以組合的,這種組合我們稱之為橋接模式。主要用在系統開始設計的時候使用。 橋接模式 橋接(Bridge)是用于把抽象化與現實化解耦,使得二者可以獨立變化,這種類型的設計模式屬于結構型模式,它通過提供抽象化和現實化之間的橋...

    jzzlee 評論0 收藏0
  • 設計模式橋接模式

    摘要:橋接模式中的所謂脫耦,就是指在一個軟件系統的抽象化和實現化之間使用關聯關系組合或者聚合關系而不是繼承關系,從而使兩者可以相對獨立地變化,這就是橋接模式的用意。 0x01.定義與類型 定義:將抽象部分與它的具體實現部分分離,使它們都可以獨立地變化。 橋接模式將繼承關系轉化成關聯關系,它降低了類與類之間的耦合度,減少了系統中類的數量,也減少了代碼量。 橋接模式中的所謂脫耦,就是指在一個軟...

    kycool 評論0 收藏0
  • JavaScript面試系列:JavaScript設計模式橋接模式和懶加載

    摘要:橋接模式的核心在于將抽象部分和它的實現部分分離,使它們都可以獨立的變化。看起來這個版本已經很完美了不,它仍然有可以優化的空間,即題目提到的橋接模式。使用橋接模式的實現版本這個實現包含了三個函數。這個例子體現了橋接模式的作用。 我寫的程序員面試系列文章 Java面試系列-webapp文件夾和WebContent文件夾的區別? 程序員面試系列:Spring MVC能響應HTTP請求的原因?...

    tracymac7 評論0 收藏0
  • 一起學設計模式 - 橋接模式

    摘要:橋接模式屬于結構型模式的一種,用于把抽象化與實現化解耦,使得二者可以獨立變化,它通過提供抽象化和實現化之間的橋接結構,來實現二者的解耦。相關模式裝飾模式與橋接模式在一定程度上都是為了減少子類的數目,避免出現復雜的繼承關系。 橋接模式(Brideg Pattern)屬于結構型模式的一種,用于把抽象化與實現化解耦,使得二者可以獨立變化,它通過提供抽象化和實現化之間的橋接結構,來實現二者的解...

    tinysun1234 評論0 收藏0
  • Java設計模式(八)——適配器模式

    摘要:適配器模式應用場景適配器模式應用場景修改已使用的接口某個已經投產中的接口需要修改,這時候使用適配器最好。適配器模式適配器模式是一種事后的補救策略。1、什么是適配器模式?Convert the interface of a class into another interface clients expect.Adapter lets classes work together that co...

    番茄西紅柿 評論0 收藏2637

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<