您还未登录! 登录 | 注册 | 帮助  

您的位置: 首页 > 软件开发专栏 > 开发技术 > 正文

工作中的设计模式 —— 门面模式

发表于:2021-04-19 作者:程序员小航 来源:程序员小航

本文转载自微信公众号「程序员小航」,作者程序员小航。转载本文请联系程序员小航公众号。

前言

门面模式也叫外观模式,是一种结构型设计模式,能为程序库、框架或其他复杂类提供一个简单的接口。

1使用场景

门面模式可以说是在工作中使用非常多的一种设计模式了,比如常用的 slf4j。

下面简单介绍常用的使用场景:

为远程接口设计统一入口

比如需要调用微信支付宝支付,里面一大堆参数,参数什么也不一样,这时候就可以统一封装一个接口,然后小伙伴们使用的时候,只需要调用封装的接口就可以了。

也不用担心同样是状态,这里叫 status,那里叫 orderStatus了。反正对外都是一个统一的门面,你自己定义即可。

好处

统一封装门面的好处,就是可以 Mock。

这也是我最近了解到的,之前都是一把嗦,谁管 junit。

Mock 就是说在 junit 测试中,使用 @MockBean 注入一个 mock 对象,然后自己定义返回。


  1. Mockito.when( xxxFacadeService.methodX()).thenReturn(mockBean); 

就是调用某个接口的时候,返回自己 mock 的对象。

这个我也是才发现的,因为我试着使用 @MockBean 注解 Dubbo 接口的对象,但是并不行。

不过还是可以变通的,所有的调用外部接口的地方,不管是 http 还是 dubbo,全部都封装了门面,这样我 mock 自己的门面接口就 ok 了。

2总结

在开发中,除了会封装很多外部接口为门面外,也会把自己的接口封装为一个门面。

也会有结合策略模式的使用,或者结合适配器模式。这些都有很多很多的使用场景,不过单独弄懂一个,后续遇到就自己扩展。

相关资料

[1] 《深入设计模式》:https://refactoringguru.cn/design-patternss

[2] 封面图:https://refactoringguru.cn/design-patterns/facade