[TOC]
# 原則
在應用程序設計的時候,如果一個模塊包含多個子模塊,那么我們就應該小心的對該模塊做出抽象
新模塊加進來,如果要我們強迫實現所有接口方法,并且還要寫一些啞方法.這樣接口稱為胖接口或者被污染的接口,使用這些接口會給系統引入一些不當的行為,這些不當的行為可能導致資源的浪費和不正確的結果
**接口隔離原則是指,客戶端不應該被強迫實現一些他們不會使用的接口,應該把胖接口中的方法分組,用多個接口代替他,每個接口服務于一個子模塊,就是使用多個專門的接口比使用單個接口要好的多**
# ISP主要觀點


**客戶端程不應該依賴他不需要的接口方法(功能),那依賴什么?
依賴他所需要的接口,客戶端需要什么接口就提供什么接口,把不需要的接口剔除,這就要求對接口進行細化,保證其純潔性**
可以看出ISP和SRP在概念上是有一定的交叉的.事實上,很多設計模式在概念上都有交叉,甚至你很難判斷一段代碼是屬于哪一個設計模式
**ISP強調的接口對客戶端所作出的承諾越少越好,并且做到專一.
當某個客戶程序要求發生變化,而迫使接口發生改變的時候,影響到其他客戶程序的可能性小.這實際就是接口污染的問題**
# 減少接口中的污染

**如果針對客戶A的方法發生改變,客戶B和客戶C并不會受到任何影響.你可能會想,這樣接口豈不是會很多?
這個問題問的好,接口既要拆,也不能拆的太細,這有個標準就是高內聚,接口應該具備一些基本的功能,能獨立完成一個基本的任務**
# 特有的方法如何實現?
根據ISP原則,這個方法可以在另一個接口的存在,讓這個'異類'同時實現2個接口
對于接口的污染,可以考慮下面這2個處理方式
1. 利用委托分離接口
2. 利用多繼承分離接口
委托模式中,有2個對象參與處理同一個請求,接受請求的對象將請求委托給另一個對象來處理,如策略模式,代理模式等中都用到了委托概念
- 書列表
- laravel框架關鍵技術
- 第一章 組件化開發與composer使用
- 簡介
- composer
- 添加路由組件
- 添加控制器模塊
- 添加模型組件
- 添加視圖組件
- 第三章 laravel框架中常用的php語法
- 匿名函數
- 文件包含
- 魔術方法
- 魔術常量
- 反射
- 后期靜態綁定
- traits
- 第四章 laravel框架中使用的HTTP協議基礎
- HTTP協議
- 數據庫
- 數據遷移
- 第六章 laravel框架中的設計模式
- IOC模式
- php核心技術與最佳實踐
- 第一章面向對象核心
- 反射
- 簡單ORM
- 異常和錯誤
- 接口
- 第二章,面向對象設計
- 設計原則
- 單一職責
- 接口隔離
- 開放封閉
- 替換原則
- 依賴倒置
- linux是怎么寫的呢?
- 第三章 正則表達
- 認識正則
- 第四章 php網絡技術應用
- HTTP協議詳解
- php和http相關函數
- 垃圾信息防御措施
- 現代操作系統
- 引論
- sql必知必會
- 限制結果
- 按位置排序
- where求職順序
- IN操作符
- like
- 函數
- group by
- 組合查詢
- 插入檢索出的數據
- 視圖
- 高性能mysql
- 第一章節 mysql架構與歷史
- mysql架構邏輯圖
- 連接與管理
- 優化與運行
- 讀寫鎖
- 鎖粒度
- 表鎖(table lock)
- 行級鎖(row lock)
- ACID
- 隔離級別
- 死鎖
- 隱式和顯式鎖定
- 多版本并發控制
- Innodb概覽
- 第四章節 Schema與數據類型優化
- 選擇優化的數據類型
- 日期和時間類型
- 標識列
- 特殊類型數據
- 表設計中的缺陷
- 范式
- 計數器表
- 第五章 創建高性能索引
- 索引基礎
- 索引類型
- 索引的優點
- 高性能索引策略
- 選擇合適的索引列順序
- 聚簇索引
- 順序的主鍵什么時候會造成更壞的后果
- 覆蓋索引
- 使用索引掃描來做排序
- 壓縮索引
- 冗余和重復索引
- 索引和鎖
- 支持多種過濾條件
- 什么是范圍條件
- 優化排序
- 維護索引和表
- 表損壞
- 減少索引和數據的碎片
- 第六章 查詢性能優化
- 掃描的行數和訪問類型
- 重構查詢方式
- 查詢執行的基礎
- 重構-改善既有代碼設計
- 第一章-重構
- 什么是重構
- 第一個案列
- 重構第一步
- 王垠博客
- 多態取代價格相關邏輯