摘要:畫一個圓使用不同的顏色,相同的抽象類方法,不同的橋的具體實現者。抽象類將持有對象。第四步創建一個具體類實現抽象類。
設計模式-橋模式原文鏈接
譯者:smallclover
個人翻譯,水平有限,如有錯誤歡迎指出,謝謝!
我們使用橋來解耦(decouple )一個抽象以及該抽象的實現。使用橋之后抽象和實現可以相互獨立的改變。這種類型的設計模式來源于結構型模式,它可以通過使用橋結構來解耦抽象類及其實現類。
這種模式涉及一個接口,它扮演一個橋的角色,使得具體類的功能獨立與接口。這兩種類型的類可以在不影響對方的情況下改變自身結構。
我們通過下面的例子來演示橋模式的使用。畫一個圓使用不同的顏色,相同的抽象類方法,不同的橋的具體實現者。
實現我們有一個DrawAPI接口,它扮演一個橋的實現化者的角色,然后會有具體的類RedCircle和GreenCircle實現接口DrawAPI。抽象類Shape將持有DrawAPI對象。BridgePatternDemo,我們的demo類將使用Shape類畫兩個不同顏色的圓。
譯者注:bridge implementer 這里翻譯為橋的實現化者,它不同于具體的實現,如:繼承,實現。這里的實現是指對橋這種概念的具體化,實現化。
第一步創建一個橋的實現化者接口DrawAPI
DrawAPI.java
public interface DrawAPI { public void drawCircle(int radius, int x, int y); }第二步
創建具體的類實現DrawApI接口
RedCircle.java
public class RedCircle implements DrawAPI { @Override public void drawCircle(int radius, int x, int y) { System.out.println("Drawing Circle[ color: red, radius: " + radius + ", x: " + x + ", " + y + "]"); } }
GreenCircle.java
public class GreenCircle implements DrawAPI { @Override public void drawCircle(int radius, int x, int y) { System.out.println("Drawing Circle[ color: green, radius: " + radius + ", x: " + x + ", " + y + "]"); } }第三步
創建一個抽象類 Shape,該類持有一個DrawAPI接口的引用。
Shape.java
public abstract class Shape { protected DrawAPI drawAPI; protected Shape(DrawAPI drawAPI){ this.drawAPI = drawAPI; } public abstract void draw(); }第四步
創建一個具體類實現抽象類Shape。
Circle.java
public class Circle extends Shape { private int x, y, radius; public Circle(int x, int y, int radius, DrawAPI drawAPI) { super(drawAPI); this.x = x; this.y = y; this.radius = radius; } public void draw() { drawAPI.drawCircle(radius,x,y); } }第五步
使用Shape和DrawAPI類畫兩個不同顏色的圓。
BridgePatternDemo.java
public class BridgePatternDemo { public static void main(String[] args) { Shape redCircle = new Circle(100,100, 10, new RedCircle()); Shape greenCircle = new Circle(100,100, 10, new GreenCircle()); redCircle.draw(); greenCircle.draw(); } }第六步
校驗輸出。
Drawing Circle[ color: red, radius: 10, x: 100, 100] Drawing Circle[ color: green, radius: 10, x: 100, 100]
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/65732.html
摘要:調用者對象會尋找合適的并且能夠處理該命令的對象,然后把該命令傳遞給相應的對象處理。緊接著創建一個類代表請求。創建具體的命令類和實現接口,它們將會作為具體的命令被處理。代表調用者,它能獲得并且發出命令。 原文連接譯者 smallclover希望對大家有所幫助。謝謝!(●?●) 設計模式-命令模式 命令模式是一種數據驅動的設計模式,屬于行為型模式這一類。命令模式會將一個請求包裝成一個對象并...
摘要:在代理模式中,我們將創建一個對象,該對象在在接口中持有原始對象,以對外部提供它的功能。實現我們將創建一個接口并且創建具體類實現接口。 原文鏈接譯者:smallclover希望對你們有所幫助,謝謝閱讀! 設計模式-代理模式 在代理模式中,我們使用一個類來代表另一個類的功能。這種類型的設計模式屬于結構型設計模式的一種。在代理模式中,我們將創建一個對象,該對象在在接口中持有原始對象,以對外部...
摘要:實現我們將創建一個接口,并且創建具體的類實現它。接下來我們需要聲明一個門面類。,我們的類將通過使用類來展示這些結果。 原文鏈接譯者:smallclover希望對大家有所幫助!Thanks for your watching 門面模式 門面模式隱藏系統的復雜性同時會提供一個接口給用戶,使得用戶可以使用該系統。這種類型的設計模式屬于結構型模式的一種,它將會添加一個接口到現有的系統當中,用戶...
摘要:迭代器模式屬于行為型模式下的一種。實現我們將創建一個接口,該接口描述迭代所需要的方法緊接著聲明了一個接口,該接口返回一個對象。我們會創建具體的類實現接口和接口,并去使用它們。第三步使用獲得迭代器并且打印。 原文地址譯者 smallclover希望對你們有所幫助 設計模式-迭代器模式 迭代器是Java和.Net程序環境下經常使用的一種設計模式。這種設計模式通常用來獲取能順序訪問集合對元素...
摘要:然后在創建一個抽象的類,該類也實現了接口,并且持有一個類的對象。第四步創建具體的裝飾器類,該類繼承了類。第五步使用裝飾對象。 原文鏈接譯者:smallclover個人翻譯,因為英語水平的原因可能會詞不達意,十分歡迎各位讀者指出其中的錯誤,希望能對讀者有1%的用處,謝謝! 設計模式-裝飾器模式 裝飾器模式允許使用者將新功能添加到現有的對象而不需要改變它的數據結構。這種類型的設計模式來源于...
閱讀 796·2023-04-26 00:30
閱讀 2704·2021-11-23 09:51
閱讀 1052·2021-11-02 14:38
閱讀 2585·2021-09-07 10:23
閱讀 2249·2021-08-21 14:09
閱讀 1389·2019-08-30 10:57
閱讀 1609·2019-08-29 11:20
閱讀 1158·2019-08-26 13:53