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

子類調(diào)用父類的方法即可完成水文報(bào)文解譯、氣象解譯中通用方法;子類中一定包含了父類的方法,這個(gè)叫繼承復(fù)用。
按照合成/聚合原則設(shè)計(jì)為:

水文協(xié)議和氣象協(xié)議中,持有編碼和位制轉(zhuǎn)換對(duì)象,通過調(diào)用對(duì)象方法即可完成復(fù)用。
示例
數(shù)據(jù)庫連接的復(fù)用:首先看通過集成關(guān)系復(fù)用數(shù)據(jù)連接代碼如下
public class SqlServerConnect {
private Connection con = null;
public Connection getCon() {
System.out.println("創(chuàng)建數(shù)據(jù)庫連接");
return con;
}
}
public class UserDao extends SqlServerConnect {
//繼承復(fù)用連接數(shù)據(jù)
public void queryData()
{
Connection con =getCon();
String sql = "select * from emp";
try {
Statement statement = con.createStatement();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
UserDao繼承了SqlServerConnect,復(fù)用了父類的getCon()方法;如果此時(shí)數(shù)據(jù)庫不再使用SQLServer,要改成oracle,這種復(fù)用就無能為力了。
使用合成復(fù)用,代碼可以修改為:
//增加一個(gè)接口
public interface DatabaseConnection {
Connection getCon();
}
//SqlServerConnect實(shí)現(xiàn)該接口
public class SqlServerConnect implements DatabaseConnection {
private Connection con = null;
@Override
public Connection getCon() {
System.out.println("創(chuàng)建數(shù)據(jù)庫連接");
return con;
}
}
//clsUserDaoNew和數(shù)據(jù)庫連接接口呈現(xiàn)聚合關(guān)系,使用依賴倒置,可動(dòng)態(tài)替換此類,復(fù)用了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類中,通過使用聚合關(guān)系,通過構(gòu)造注入一個(gè)數(shù)據(jù)連接對(duì)象,通過調(diào)用這個(gè)對(duì)象的getCon()方法實(shí)現(xiàn)復(fù)用。這種方式,利用里氏代換和依賴倒置原則,當(dāng)使用SQLServer數(shù)據(jù)庫時(shí),注入SqlServerConnect實(shí)例,如果使用oracle數(shù)據(jù)庫時(shí),注入OrcaleConnect實(shí)例,代碼更加靈活,實(shí)現(xiàn)動(dòng)態(tài)復(fù)用。
拓展
1.繼承是靜態(tài)復(fù)用,通過聚合復(fù)用是動(dòng)態(tài)復(fù)用。所謂的靜態(tài)復(fù)用是在編碼階段已經(jīng)明確了類之間的關(guān)系;動(dòng)態(tài)復(fù)用則是在程序運(yùn)行階段,根據(jù)實(shí)際要求注入相應(yīng)的對(duì)象完成復(fù)用的,動(dòng)態(tài)復(fù)用比靜態(tài)復(fù)用更具有靈活性。
2.合成復(fù)用原則還體現(xiàn)復(fù)用范圍擴(kuò)大了。如上圖所示,使用繼承關(guān)系,則BCD轉(zhuǎn)ASCII碼只服務(wù)報(bào)文解譯,如一個(gè)加密程序也要使用BCD轉(zhuǎn)ASCII、數(shù)據(jù)位制轉(zhuǎn)換,就沒辦法使用。
以上就是java面向?qū)ο笤O(shè)計(jì)原則之合成復(fù)用原則示例詳解的詳細(xì)內(nèi)容,更多關(guān)于java面向?qū)ο笤O(shè)計(jì)原則的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
java 中String和StringBuffer與StringBuilder的區(qū)別及使用方法
這篇文章主要介紹了java 中String和StringBuffer與StringBuilder的區(qū)別及使用方法的相關(guān)資料,在開發(fā)過程中經(jīng)常會(huì)用到String 這個(gè)類進(jìn)行操作,需要的朋友可以參考下2017-08-08
SpringBoot集成Druid監(jiān)控慢SQL的詳細(xì)過程
數(shù)據(jù)庫連接池是一個(gè)至關(guān)重要的組成部分,一個(gè)優(yōu)秀的數(shù)據(jù)庫連接池可以顯著提高應(yīng)用程序的性能和可伸縮性,常見的連接池:Druid、HikariCP、C3P0、DBCP等等,本文將詳細(xì)介紹如何在Spring Boot項(xiàng)目中配置數(shù)據(jù)源,集成Druid連接池,以實(shí)現(xiàn)更高效的數(shù)據(jù)庫連接管理2024-06-06
Maven項(xiàng)目打包成war包部署到Tomcat的方法
這篇文章主要介紹了Maven項(xiàng)目打包成war包部署到Tomcat的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-06-06
從0到1學(xué)SpringCloud之SpringCloud?gateway網(wǎng)關(guān)路由配置示例詳解
Spring?Cloud?Gateway的目標(biāo)提供統(tǒng)一的路由方式且基于Filter?鏈的方式提供了網(wǎng)關(guān)基本的功能,?例如:安全、監(jiān)控、指標(biāo)和限流?,這篇文章主要介紹了從0到1學(xué)SpringCloud之SpringCloud?gateway網(wǎng)關(guān)路由配置示例詳解,需要的朋友可以參考下2023-04-04
HttpServletResponse亂碼問題_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了HttpServletResponse亂碼問題,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07
idea創(chuàng)建maven父子工程導(dǎo)致子工程無法導(dǎo)入父工程依賴
創(chuàng)建maven父子工程時(shí)遇到一個(gè)問題,本文主要介紹了idea創(chuàng)建maven父子工程導(dǎo)致子工程無法導(dǎo)入父工程依賴,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04
springboot實(shí)現(xiàn)分段上傳功能的示例代碼
這篇文章主要介紹了springboot實(shí)現(xiàn)分段上傳,包括文件上傳下載,斷點(diǎn)續(xù)傳,增量上傳功能,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07

