189 8069 5689

设计模式之迭代器模式引导篇-创新互联

迭代器模式-引导篇

创新互联服务项目包括博望网站建设、博望网站制作、博望网页制作以及博望网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,博望网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到博望省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!

设计模式之迭代器模式 引导篇

这两天,比较火的并购新闻就是,网易考拉被阿里以20亿美元收购。从此网易考拉不再姓“网”而姓“阿”了。并购后的网易考拉和阿里的电商系统进行对接。那么问题来了:在阿里有个早餐店的菜单(CakeHouseMenu)使用的事ArrayList来存放菜单的,考拉有个午餐店的菜单(DinerMenu)使用的是数组结构存放的。现在考拉和阿里合并了,两个点的菜单也要合并。

设计模式之迭代器模式 引导篇

我们先来看看第一版设计:

因为马爸爸说了,国庆之前,必须合并上线,时间紧任务中,肿么办?那就再创建一个对象,使用一个菜单对象,将早餐店对象机午餐店对象作为属性,调用的时候,直接调用各自对象的就可以。类图如下:

设计模式之迭代器模式 引导篇

顾客来了,点早餐,服务器就从菜单中调用早餐店的get方法。得到KFC早餐套餐

如果点的是午餐,就从菜单中调用午餐店的getMenuItem方法,得到快餐一份。

代码如下:

设计模式之迭代器模式 引导篇

运行ConventionalMainTest运行结果:

设计模式之迭代器模式 引导篇

我们可以看到,早餐、午餐菜单也都打印出来了。正常啊,没问题啊。

我们先来看看服务员(waitress)对象里面内容:

设计模式之迭代器模式 引导篇

从上图中,我们可以看到在服务员对象中有早餐店对象、午餐店对象、list类型的items以及数组类型的items。从运行结果上来看,是没有问题的。但是要是过了N+X天后,马爸爸又玩起了收购肿么办?假设收购的是X店。X店的菜单使用的是hashTable这种类型的。

难道,我们要在waitress中在添加X店对象同时添加hashTabel类型的items吗?好,就算收购一个,添加一个可以。

那么如果收购了M+N个店。菜单数据类型使用了W种类型。难道,每次都修改waiters这个类吗?

设计模式之迭代器模式 引导篇

这样行是行,但是在后期维护、管理比较麻烦。而且还违背了开闭原则(对修改是封闭的,对扩展是开放的)。那么怎么办呢?

来源:凯哥Java(kaigejava)。

凯哥个人博客:www.kaigejava.com

思考:

我们在开发的时候,针对接口开发,这样耦合度也可以降低。我们假设两个饭店的菜单都实现了一个接口。然后waiter对象只要拥有接口对象就可以。

封装遍历的顶级接口,迭代器类图如下:

设计模式之迭代器模式 引导篇

我们用迭代器接口来修改菜单:

设计模式之迭代器模式 引导篇

说明:

CakeHouseIterator和DinerIterator两个类是实现了Iterator接口的

修改两个饭店获取getIterator的方法。返回对应放到实现iterator接口的对象。

我们来看早餐店的iterator对象:

设计模式之迭代器模式 引导篇

在重写hasNext机next方法。

我们在来看看修改后的服务员对象:

设计模式之迭代器模式 引导篇

这个时候,服务员对象只有iterator对象了。已经实现了对早餐店及午餐店的解耦。

再来看看测试类:

设计模式之迭代器模式 引导篇

在服务员对象添加菜单的时候,是不知道具体添加的是早餐店的菜单还是午餐店的菜单。实现了解耦。

这样做的好处:

一:类之间实现了松耦合

二:就算考拉修改了菜单数据结构也不影响服务员的点餐。也是实现耦合的一种表现。

不写了,太困了。已经7号凌晨一点多了。各位看官,今日太累了,写不不好,在迭代器总结篇好好补上。

本文作者:凯哥Java(kaigejava)

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


本文名称:设计模式之迭代器模式引导篇-创新互联
当前URL:http://cdxtjz.cn/article/dcejjd.html

其他资讯