外觀模式介紹
外觀模式(Facade Pattern)机断,在開(kāi)發(fā)過(guò)程中運(yùn)用頻率非常高描焰,無(wú)論是做 SDK 還是封裝API,我們大多都會(huì)用到外觀模式碍现,它通過(guò)一個(gè)外觀類使得整個(gè)系統(tǒng)的結(jié)構(gòu)只有一個(gè)統(tǒng)一的高層接口悠砚,這樣能降低用戶的使用成本。
外觀模式定義
為系統(tǒng)中的一組接口提供一個(gè)一致的界面堂飞,此模式定義了一個(gè)高層接口灌旧,這個(gè)接口使得子系統(tǒng)更加容易使用。
外觀模式使用場(chǎng)景
- 構(gòu)建一個(gè)有層次結(jié)構(gòu)的子系統(tǒng)時(shí)绰筛,使用外觀模式定義子系統(tǒng)中每層的入口點(diǎn)枢泰,如果子系統(tǒng)之間是相互依賴的,則可以讓他們通過(guò)外觀接口進(jìn)行通信铝噩,減少子系統(tǒng)之間的依賴關(guān)系衡蚂。
- 子系統(tǒng)往往會(huì)因?yàn)椴粩嗟闹貥?gòu)演化而變得越來(lái)越復(fù)雜,大多數(shù)的模式使用時(shí)也會(huì)產(chǎn)生很多很小的類,這給外部調(diào)用他們的用戶程序帶來(lái)了使用的困難毛甲,我們可以使用外觀類提供一個(gè)簡(jiǎn)單的接口年叮,對(duì)外隱藏子系統(tǒng)的具體實(shí)現(xiàn)并隔離變化。
外觀模式 UML 類圖
角色介紹:
- Facade:外觀類玻募,知道哪些子系統(tǒng)類負(fù)責(zé)處理請(qǐng)求只损,將客戶端的請(qǐng)求代理給適當(dāng)?shù)淖酉到y(tǒng)對(duì)象。
- Subsystem:子系統(tǒng)類七咧,實(shí)現(xiàn)子系統(tǒng)的功能跃惫,處理外觀類指派的任務(wù),注意子系統(tǒng)類不含有外觀類的引用艾栋。
外觀模式的實(shí)現(xiàn)
這里以手機(jī)為例爆存,它集合了電話、短信蝗砾、相機(jī)等功能先较,通過(guò)手機(jī)就可以完成各種功能,而無(wú)需每一個(gè)模塊都獨(dú)立出來(lái)遥诉。通過(guò)手機(jī)對(duì)象完成完成各個(gè)模塊功能的調(diào)用拇泣,這就是外觀模式。
子系統(tǒng)類(Subsystem)
電話子系統(tǒng)
public interface Phone {
void dial();
void hangup();
}
public class PhoneImpl implements Phone {
@Override
public void dial() {
System.out.println("打電話");
}
@Override
public void hangup() {
System.out.println("掛斷");
}
}
相機(jī)子系統(tǒng)
public interface Camera {
void open();
void takePicture();
void close();
}
public class CameraImpl implements Camera {
@Override
public void open() {
System.out.println("打開(kāi)相機(jī)");
}
@Override
public void takePicture() {
System.out.println("拍照");
}
@Override
public void close() {
System.out.println("關(guān)閉相機(jī)");
}
}
外觀類(Facade)
手機(jī)統(tǒng)一用戶調(diào)用接口
public class MobilePhone {
private Phone mPhone = new PhoneImpl();
private Camera mCamera = new CameraImpl();
public void dial() {
mPhone.dial();
}
public void videoChat() {
System.out.println("視頻聊天接通中...");
mCamera.open();
mPhone.dial();
System.out.println("視頻聊天已接通");
}
public void hangup() {
mPhone.hangup();
}
public void takePicture() {
mCamera.open();
mCamera.takePicture();
}
public void closeCamera() {
mCamera.close();
}
}
運(yùn)行結(jié)果:
打電話
視頻聊天接通中...
打開(kāi)相機(jī)
打電話
視頻聊天已接通
從上面的代碼可以看到矮锈,外觀模式就是統(tǒng)一接口封裝霉翔,將子系統(tǒng)的邏輯、交互隱藏苞笨,及時(shí)具體的子系統(tǒng)發(fā)生變化债朵,用戶也不會(huì)感知到,變化隔離開(kāi)來(lái)瀑凝,我們的系統(tǒng)也更為靈活序芦。
總結(jié)
優(yōu)點(diǎn)
1.對(duì)客戶程序隱藏子系統(tǒng)細(xì)節(jié),因而減少客戶對(duì)于子系統(tǒng)的耦合粤咪。
2.外觀類對(duì)子系統(tǒng)的接口封裝谚中,使得系統(tǒng)更易于使用。
缺點(diǎn)
- 外觀類沒(méi)有遵循開(kāi)閉原則寥枝,業(yè)務(wù)變更時(shí)宪塔,可能需要直接修改外觀類。