外观模式(Facade)介绍

外观模式也叫门面模式

外观模式就是提供一个统一的接口,用来访问子系统中的一群接口。外观模式定义了一个高层接口,让子系统更容易使用。如下图,是使用外观模式后将子系统的使用变得更加简单。

image.png

说起来比较复杂,实际上在日常生活中经常能遇到。比如部门安排出差,需要去淘宝买出差洗漱用品,一共有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\n", toiletries_type[type]);

}

void buy_shampoo(int type)

{

    printf("buy %s shampoo\n", toiletries_type[type]);

}

void buy_toothpaste(int type)

{

    printf("buy %s toothpaste\n", toiletries_type[type]);

}

void buy_bodylotion(int type)

{

    printf("buy %s body wash\n", 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

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐