簡單理解遵循接口隔離原則的Java設(shè)計模式編程
定義:客戶端不應該依賴它不需要的接口;一個類對另一個類的依賴應該建立在最小的接口上。
問題由來:類A通過接口I依賴類B,類C通過接口I依賴類D,如果接口I對于類A和類B來說不是最小接口,則類B和類D必須去實現(xiàn)他們不需要的方法。
解決方案:將臃腫的接口I拆分為獨立的幾個接口,類A和類C分別與他們需要的接口建立依賴關(guān)系。也就是采用接口隔離原則。
舉例來說明接口隔離原則:

這個圖的意思是:類A依賴接口I中的方法1、方法2、方法3,類B是對類A依賴的實現(xiàn)。類C依賴接口I中的方法1、方法4、方法5,類D是對類C依賴的實現(xiàn)。對于類B和類D來說,雖然他們都存在著用不到的方法(也就是圖中紅色字體標記的方法),但由于實現(xiàn)了接口I,所以也必須要實現(xiàn)這些用不到的方法。
我們首先先看一個違反接口隔離的例子:
public interface IWorker {
public void work();
public void eat();
}
public class Worker implements IWorker{
@Override
public void work() {
// TODO 工人工作
}
@Override
public void eat() {
// TODO 工人吃飯
}
}
public class Robot implements IWorker {
@Override
public void work() {
// TODO 機器人工作
}
@Override
public void eat() {
// TODO 機器人吃飯?
}
}
由于機器人是不需要吃飯的,所以IWorker被認為是一個臃腫的接口,當然你也可以在Robot類中的eat方法做空實現(xiàn),但是這樣可能會產(chǎn)生不可預計的BUG,比如eat方法需要消耗盒飯數(shù)量的話,就會出現(xiàn)不對應的現(xiàn)象。
下面是修改后的實現(xiàn):
public interface IWorker {
public void work();
}
public interface IDiet {
public void eat();
}
public class Worker implements IWorker, IDiet{
@Override
public void work() {
// TODO 工人工作
}
@Override
public void eat() {
// TODO 工人吃飯
}
}
public class Robot implements IWorker {
@Override
public void work() {
// TODO 機器人工作
}
}
總結(jié):
1. 接口要盡量小,并高內(nèi)聚,不過要適當,太細化不好維護。
2. 如果已經(jīng)設(shè)計成了臃腫的接口,可以使用適配器模式隔離它。
相關(guān)文章
Java執(zhí)行cmd命令兩種實現(xiàn)方法解析
這篇文章主要介紹了Java執(zhí)行cmd命令兩種實現(xiàn)方法解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-07-07
詳解mybatis 批量更新數(shù)據(jù)兩種方法效率對比
這篇文章主要介紹了詳解mybatis 批量更新數(shù)據(jù)兩種方法效率對比,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-02-02
springboot集成PageHelper分頁失效的原因及解決
項目啟動初期,在集成mybatis的分頁插件,自定義封裝了一個分頁的工具類,方便后期項目的擴展,結(jié)果無法分頁了,怎么設(shè)置搞都沒辦法正常分頁,所以本文將給大家介紹一下springboot集成PageHelper分頁失效的原因及解決,需要的朋友可以參考下2023-10-10
mybatis調(diào)用mysql存儲過程(返回參數(shù),單結(jié)果集,多結(jié)果集)
本文主要介紹了mybatis調(diào)用mysql存儲過程(返回參數(shù),單結(jié)果集,多結(jié)果集),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01

