外观模式(Facade)介绍
外观模式也叫门面模式
外观模式就是提供一个统一的接口,用来访问子系统中的一群接口。外观模式定义了一个高层接口,让子系统更容易使用。如下图,是使用外观模式后将子系统的使用变得更加简单。
说起来比较复杂,实际上在日常生活中经常能遇到。比如部门安排出差,需要去淘宝买出差洗漱用品,一共有4中东西要选择。洗面奶,牙膏,洗发水,润肤露。消费者可以自己一个买,也可以买套餐。把上图大方框外的小方块看成不同的消费者,里面的小方块看成洗面奶之类。Façade就是店家提供的不同套餐选择的那个接口。
外观模式实现
#define BIG_BOTTLE 0
#define MID_BOTTLE 1
#define SMALL_BOTTLE 2
char *toiletries_type[] =
{
"big bottle",
"middle bottle"
"small bottle"
};
void buy_face_soap(int type)
{
printf("buy %s face soap
", toiletries_type[type]);
}
void buy_shampoo(int type)
{
printf("buy %s shampoo
", toiletries_type[type]);
}
void buy_toothpaste(int type)
{
printf("buy %s toothpaste
", toiletries_type[type]);
}
void buy_bodylotion(int type)
{
printf("buy %s body wash
", toiletries_type[type]);
}
在普通模式里,外部client可以随意调用内部的接口。
void client_buy_normal()
{
buy_face_soap(MID_BOTTLE);
buy_face_soap(MID_BOTTLE);
buy_shampoo(BIG_BOTTLE);
buy_shampoo(MID_BOTTLE);
buy_toothpaste(SMALL_BOTTLE);
buy_toothpaste(MID_BOTTLE);
buy_bodylotion(BIG_BOTTLE);
}
实现了两个封装好的接口pack_for_woman和pack_for_man。不允许外部client调用内部接口,只允许调用封装好的facade接口pack_for_woman和pack_for_man。
void pack_for_woman()
{
buy_face_soap(MID_BOTTLE);
buy_shampoo(BIG_BOTTLE);
buy_toothpaste(SMALL_BOTTLE);
buy_bodylotion(BIG_BOTTLE);
}
void pack_for_man()
{
buy_face_soap(MID_BOTTLE);
buy_shampoo(MID_BOTTLE);
buy_toothpaste(MID_BOTTLE);
}
void client_buy_with_facade()
{
pack_for_woman();
pack_for_man();
}
在原始函数和外观模式实现里,买的东西都一样。
模式实现总结
引入外观模式,是客户对子系统的使用变得简单了,减少了与子系统的关联对象,实现了子系统与客户之间的松耦合关系。但是,灵活性变差了,客户不能自由选择子系统内部的接口,只能使用封装好的一套接口。
实际生活里,客户并不是需要选子系统内部接口。比如DIY电脑就相当于普通的模式,消费者会买cpu,主板等各个组件。而品牌PC就类似于门面模式,只能购买特定个型号。对于手机就更不用说了,没有消费者能买soc,flash来装手机。
来源:华为云社区 作者:lurayvis