概念
盡量使用合成/聚合,而不是使用繼承實現復用。所謂的合成/聚合是指一個對象里持有另外一個類的對象,通過調用這些對象的方法得到復用已有功能的目的。如:報文解譯程序中,按照繼承復用可以設計為:
子類調用父類的方法即可完成水文報文解譯、氣象解譯中通用方法;子類中一定包含了父類的方法,這個叫繼承復用。
按照合成/聚合原則設計為:
水文協議和氣象協議中,持有編碼和位制轉換對象,通過調用對象方法即可完成復用。
示例
數據庫連接的復用:首先看通過集成關系復用數據連接代碼如下
public class SqlServerConnect { private Connection con = null; public Connection getCon() { System.out.println("創建數據庫連接"); return con; } } public class UserDao extends SqlServerConnect { //繼承復用連接數據 public void queryData() { Connection con =getCon(); String sql = "select * from emp"; try { Statement statement = con.createStatement(); } catch (SQLException e) { e.printStackTrace(); } } }
UserDao繼承了SqlServerConnect,復用了父類的getCon()方法;如果此時數據庫不再使用SQLServer,要改成oracle,這種復用就無能為力了。
使用合成復用,代碼可以修改為:
//增加一個接口 public interface DatabaseConnection { Connection getCon(); } //SqlServerConnect實現該接口 public class SqlServerConnect implements DatabaseConnection { private Connection con = null; @Override public Connection getCon() { System.out.println("創建數據庫連接"); return con; } } //clsUserDaoNew和數據庫連接接口呈現聚合關系,使用依賴倒置,可動態替換此類,復用了getCon()代碼 public class UserDaoNew { private DatabaseConnection objCon; public UserDaoNew(DatabaseConnection conn){ objCon = conn; } public void queryData() { Connection con = objCon.getCon(); String sql = "select * from emp"; try { Statement statement = con.createStatement(); } catch (SQLException e) { e.printStackTrace(); } } }
在UserDaoNew類中,通過使用聚合關系,通過構造注入一個數據連接對象,通過調用這個對象的getCon()方法實現復用。這種方式,利用里氏代換和依賴倒置原則,當使用SQLServer數據庫時,注入SqlServerConnect實例,如果使用oracle數據庫時,注入OrcaleConnect實例,代碼更加靈活,實現動態復用。
拓展
1.繼承是靜態復用,通過聚合復用是動態復用。所謂的靜態復用是在編碼階段已經明確了類之間的關系;動態復用則是在程序運行階段,根據實際要求注入相應的對象完成復用的,動態復用比靜態復用更具有靈活性。
2.合成復用原則還體現復用范圍擴大了。如上圖所示,使用繼承關系,則BCD轉ASCII碼只服務報文解譯,如一個加密程序也要使用BCD轉ASCII、數據位制轉換,就沒辦法使用。
以上就是java面向對象設計原則之合成復用原則示例詳解的詳細內容,更多關于java面向對象設計原則的資料請關注服務器之家其它相關文章!
原文鏈接:https://blog.csdn.net/guoyp2126/article/details/113946537