重写设计模式——模版模式

作者: justCode_ | 来源:发表于2018-03-05 10:04 被阅读0次

    为什么要重写?其实设计模式已经被写烂了,基本上,网络上都是一抄一大篇,当然,我之前也是用了很多别人的文章(还好备注了,是别人写的,不然就是抄袭了)!我重写的原因,其实是想加入一些自己平时学习,工作中,遇到的情况。然后怎么想到用这个模式,或者我用了某个模式,后来一查,卧槽,原来早就有人这么用了。

    我就不按网上那些资料写了,按自己的方式写了。

    先说一下场景吧,我一个项目中,用到了蓝牙。其中一个模块是:蓝牙扫描功能,伪代码是这样的

    1.检查蓝牙是否开启

    if(bleIsOpen){

    1.1蓝牙开启:扫描附近蓝牙

    scanBle()

    }else{

    1.2蓝牙未开启:打开蓝牙

    openBle()

    }

    2.处理蓝牙扫描结果

    doScanResult(Device device)

    扫描模块基本的功能就是这样,但是,在1.1这一步的时候,发现,扫描这个功能,其实,是有几种情况的,

    首先是低功率和正常功率问题:这是蓝牙的扫描模式,低功率模式,快,省电,但(不稳定,但这个问题,通常会忽略,因为就算不稳定,但基本能连上),正常功率模式相对慢,耗电,但稳定;

    然后就是版本问题,高版本API和低版本API之间的不兼容:Android5.0之后,有一种更高效,更稳定的低功率扫描,但是低版本,没有这一套API。

    针对上述问题,所以,就需要重新做一些调整。

    1.检查蓝牙是否开启

    if(bleIsOpen){

    1.1蓝牙开启:扫描附近蓝牙

    1.1.1根据API版本高版本还是低版本扫描模式

    if(isHeigh){

    scanBleByHeighAPI()

    }else{

    scanBleByNorAPI()

    }

    }else{

    1.2蓝牙未开启:打开蓝牙

    openBle()

    }

    2.处理蓝牙扫描结果

    doScanResult(Device device)

    这个时候,网上的资料通常会说,这样改之后,还是会有问题的,就是如果后面又有新的扫描模式,又要加判断,破环结构什么的。说实话,其实,个人觉得,这个理由不够充分,我真不会为了这个东西,去强行改代码。因为,就算这么写,又有什么关系,业务照样是能实现的。

    但是,我还是要在改一下,原因是:

    1.从代码阅读和业务代码的角度而言,应该更纯粹一点。业务代码,只写业务。因为这里,扫描和处理扫描结果,都是属于业务代码,但是,怎么扫描,怎么处理结果,那是实现的问题,应该抽取出去。

    2.扫描和处理结果,应该是成对的(或许结果都是一样,但是不排除,API的处理方式不同,或者有什么新的更新,导致处理方式不同,这一点是因为吃了百度地图API的亏)

    ok,就这两个理由,让我决定要改它。

    然后,我就这样改了

    当然,代码没有写得很完整,旨在描述这个过程,业务。

    好了,最后再总结一下(网上那些一抄一大篇的写法):

    优点

    模板方法模式通过把不变的行为搬移到超类,去除了子类中的重复代码。

    子类实现算法的某些细节,有助于算法的扩展。

    通过一个父类调用子类实现的操作,通过子类扩展增加新的行为,符合“开放-封闭原则”。

    缺点

    每个不同的实现都需要定义一个子类,这会导致类的个数的增加,设计更加抽象。

    适用场景

    在某些类的算法中,用了相同的方法,造成代码的重复。

    控制子类扩展,子类必须遵守算法规则。

    上述,是网上抄过来的,基本都是这么写的。面试,可以这样答,不过,感觉没什么卵用。

    但是,我自己的总结是:

    优点

    业务代码在父类(抽象类),技术代码(实现)在子类;

    调用更简单,忽略细节,直观业务逻辑;

    缺点

    不会用,你就写不来。(什么子类多之类的问题,只要你把包分好了,归类做好,也不存在的)

    场景:

    看个人理解,我已经举了一个工作中的实例了。基本来说就是,同一个功能(方法),多种实现方式,用这个,基本都可以。

    相关文章

      网友评论

        本文标题:重写设计模式——模版模式

        本文链接:https://www.haomeiwen.com/subject/vvucfftx.html