java面向對象設計原則之合成復用原則示例詳解
概念
盡量使用合成/聚合,而不是使用繼承實現(xiàn)復用。所謂的合成/聚合是指一個對象里持有另外一個類的對象,通過調用這些對象的方法得到復用已有功能的目的。如:報文解譯程序中,按照繼承復用可以設計為:

子類調用父類的方法即可完成水文報文解譯、氣象解譯中通用方法;子類中一定包含了父類的方法,這個叫繼承復用。
按照合成/聚合原則設計為:

水文協(xié)議和氣象協(xié)議中,持有編碼和位制轉換對象,通過調用對象方法即可完成復用。
示例
數據庫連接的復用:首先看通過集成關系復用數據連接代碼如下
public class SqlServerConnect {
private Connection con = null;
public Connection getCon() {
System.out.println("創(chuàng)建數據庫連接");
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實現(xiàn)該接口
public class SqlServerConnect implements DatabaseConnection {
private Connection con = null;
@Override
public Connection getCon() {
System.out.println("創(chuàng)建數據庫連接");
return con;
}
}
//clsUserDaoNew和數據庫連接接口呈現(xiàn)聚合關系,使用依賴倒置,可動態(tài)替換此類,復用了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()方法實現(xiàn)復用。這種方式,利用里氏代換和依賴倒置原則,當使用SQLServer數據庫時,注入SqlServerConnect實例,如果使用oracle數據庫時,注入OrcaleConnect實例,代碼更加靈活,實現(xiàn)動態(tài)復用。
拓展
1.繼承是靜態(tài)復用,通過聚合復用是動態(tài)復用。所謂的靜態(tài)復用是在編碼階段已經明確了類之間的關系;動態(tài)復用則是在程序運行階段,根據實際要求注入相應的對象完成復用的,動態(tài)復用比靜態(tài)復用更具有靈活性。
2.合成復用原則還體現(xiàn)復用范圍擴大了。如上圖所示,使用繼承關系,則BCD轉ASCII碼只服務報文解譯,如一個加密程序也要使用BCD轉ASCII、數據位制轉換,就沒辦法使用。
以上就是java面向對象設計原則之合成復用原則示例詳解的詳細內容,更多關于java面向對象設計原則的資料請關注腳本之家其它相關文章!
相關文章
SpringBoot實現(xiàn)國密SM4加密解密的使用示例
在商用密碼體系中,SM4主要用于數據加密,本文就來介紹一下SpringBoot實現(xiàn)國密SM4加密解密的使用示例,具有一定的參考價值,感興趣的可以了解一下2023-10-10

