AVA设计模式初探之组合模式
先看看组合模式的定义吧:“将对象组合成树形结构以表示‘部分-整体’的层次结构。组合模式使得用户对单个对象和组合对象的使用具有一致性。”
就拿剪发办卡的事情来分析一下吧。
首先,一张卡可以在总部,分店,加盟店使用,那么总部可以刷卡,分店也可以刷卡,加盟店也可以刷卡,这个属性结构的店面层级关系就明确啦。
那么,总店刷卡消费与分店刷卡消费是一样的道理,那么总店与分店对会员卡的使用也具有一致性。
1.组合模式的例子
那么组合模式的实例如下:
- import java.util.ArrayList;
- import java.util.List;
- public class ComponentDemo {
- public abstract class Component {
- String name;
- public abstract void add(Component c);
- public abstract void remove(Component c);
- public abstract void eachChild();
- }
- // 组合部件类
- public class Leaf extends Component {
- // 叶子节点不具备添加的能力,所以不实现
- @Override
- public void add(Component c) {
- // TODO Auto-generated method stub
- System.out.println("");
- }
- // 叶子节点不具备添加的能力必然也不能删除
- @Override
- public void remove(Component c) {
- // TODO Auto-generated method stub
- System.out.println("");
- }
- // 叶子节点没有子节点所以显示自己的执行结果
- @Override
- public void eachChild() {
- // TODO Auto-generated method stub
- System.out.println(name + "执行了");
- }
- }
- // 组合类
- public class Composite extends Component {
- // 用来保存节点的子节点
- List<Component> list = new ArrayList<Component>();
- // 添加节点 添加部件
- @Override
- public void add(Component c) {
- // TODO Auto-generated method stub
- list.add(c);
- }
- // 删除节点 删除部件
- @Override
- public void remove(Component c) {
- // TODO Auto-generated method stub
- list.remove(c);
- }
- // 遍历子节点
- @Override
- public void eachChild() {
- // TODO Auto-generated method stub
- System.out.println(name + "执行了");
- for (Component c : list) {
- c.eachChild();
- }
- }
- }
- public static void main(String[] args) {
- ComponentDemo demo = new ComponentDemo();
- // 构造根节点
- Composite rootComposite = demo.new Composite();
- rootComposite.name = "根节点";
- // 左节点
- Composite compositeLeft = demo.new Composite();
- compositeLeft.name = "左节点";
- // 构建右节点,添加两个叶子几点,也就是子部件
- Composite compositeRight = demo.new Composite();
- compositeRight.name = "右节点";
- Leaf leaf1 = demo.new Leaf();
- leaf1.name = "右-子节点1";
- Leaf leaf2 = demo.new Leaf();
- leaf2.name = "右-子节点2";
- compositeRight.add(leaf1);
- compositeRight.add(leaf2);
- // 左右节点加入 根节点
- rootComposite.add(compositeRight);
- rootComposite.add(compositeLeft);
- // 遍历组合部件
- rootComposite.eachChild();
- }
- }
执行结果如下:
2.应用组合模式的会员卡消费
那么我们就根据我们会员卡的消费,来模拟一下组合模式的实现吧!let's go!
首先:
1.我们的部件有,总店,分店,加盟店!
2.我们的部件共有的行为是:刷会员卡
3.部件之间的层次关系,也就是店面的层次关系是,总店下有分店、分店下可以拥有加盟店。
有了我们这几个必要条件后,我的要求就是目前店面搞活动当我在总店刷卡后,就可以累积相当于在所有下级店面刷卡的积分总额,设计的代码如下:
- import java.util.ArrayList;
- import java.util.List;
- public class PayDemo {
- public abstract class Market {
- String name;
- public abstract void add(Market m);
- public abstract void remove(Market m);
- public abstract void PayByCard();
- }
- // 分店 下面可以有加盟店
- public class MarketBranch extends Market {
- // 加盟店列表
- List<Market> list = new ArrayList<PayDemo.Market>();
- public MarketBranch(String s) {
- this.name = s;
- }
- @Override
- public void add(Market m) {
- // TODO Auto-generated method stub
- list.add(m);
- }
- @Override
- public void remove(Market m) {
- // TODO Auto-generated method stub
- list.remove(m);
- }
- // 消费之后,该分店下的加盟店自动累加积分
- @Override
- public void PayByCard() {
- // TODO Auto-generated method stub
- System.out.println(name + "消费,积分已累加入该会员卡");
- for (Market m : list) {
- m.PayByCard();
- }
- }
- }
- // 加盟店 下面不在有分店和加盟店,最底层
- public class MarketJoin extends Market {
- public MarketJoin(String s) {
- this.name = s;
- }
- @Override
- public void add(Market m) {
- // TODO Auto-generated method stub
- }
- @Override
- public void remove(Market m) {
- // TODO Auto-generated method stub
- }
- @Override
- public void PayByCard() {
- // TODO Auto-generated method stub
- System.out.println(name + "消费,积分已累加入该会员卡");
- }
- }
- public static void main(String[] args) {
- PayDemo demo = new PayDemo();
- MarketBranch rootBranch = demo.new MarketBranch("总店");
- MarketBranch qhdBranch = demo.new MarketBranch("秦皇岛分店");
- MarketJoin hgqJoin = demo.new MarketJoin("秦皇岛分店一海港区加盟店");
- MarketJoin btlJoin = demo.new MarketJoin("秦皇岛分店二白塔岭加盟店");
- qhdBranch.add(hgqJoin);
- qhdBranch.add(btlJoin);
- rootBranch.add(qhdBranch);
- rootBranch.PayByCard();
- }
- }
运行结果如下:
这样在累积所有子店面积分的时候,就不需要去关心子店面的个数了,也不用关系是否是叶子节点还是组合节点了,也就是说不管是总店刷卡,还是加盟店刷卡,都可以正确有效的计算出活动积分。
3.什么情况下使用组合模式
引用大话设计模式的片段:“当发现需求中是体现部分与整体层次结构时,以及你希望用户可以忽略组合对象与单个对象的不同,统一地使用组合结构中的所有对象时,就应该考虑组合模式了。”
作者:jason0539
微博:http://weibo.com/2553717707
博客:http://blog.csdn.net/jason0539(转载请说明出处)
AVA设计模式初探之组合模式相关推荐
- JAVA设计模式初探之组合模式
先看看组合模式的定义吧:"将对象组合成树形结构以表示'部分-整体'的层次结构.组合模式使得用户对单个对象和组合对象的使用具有一致性." 就拿剪发办卡的事情来分析一下吧. 首先,一张 ...
- 组合模式_设计模式结构性:组合模式(CompositePattern)
组合模式(Composite Pattern),又叫部分整体模式,是用于把一组相似的对象当作一个单一的对象.组合模式依据树形结构来组合对象,用来表示部分以及整体层次.这种类型的设计模式属于结构型模式, ...
- 从王者荣耀看设计模式(五.组合模式)
从王者荣耀看设计模式(组合模式) 一.简介 在王者荣耀这款游戏中,我们可以在商店中购买英雄.英雄由法师.射手.打野等职业组合而成,其中各个职业由中国元素的英雄和外国元素的英雄组成,玩家可根据需要挑选并 ...
- 《设计模式》12.组合模式(结构型)
又称"整体-部分"模式,组合多个对象形成树形结构以表示具有"整体-部分"关系的层次结构,使用户对单个对象和组合对象具有访问一致性. 角色 抽象构件(Compon ...
- JAVA设计模式十七--Composite(组合模式)
组合模式 组合模式(Composite Pattern)有时候又叫做部分-整体模式,它使我们树型结构的问题中,模糊了简单元素和复杂元素的概念 ,客户程序可以向处理简单元素一样来处理复杂元素,从而使 ...
- 再战设计模式(九)之组合模式
组合模式 工作流程分析 组合模式为处理树形结构提供了完美的解决方案,描述了如何将容器和叶子进行递归组合,使得用户在使用时可以一致性的对待容器和叶子 当容器对象的指定方法被调用时,将遍历整个树形结构,寻 ...
- 设计模式(17)之组合模式
一.前言 在现实生活中,存在很多"部分-整体"的关系,例如,大学中的部门与学院.总公司中的部门与分公司.学习用品中的书与书包.生活用品中的衣服与衣柜.以及厨房中的锅碗瓢盆等.在软件 ...
- 设计模式:(组合模式)
1.定义 组合模式(Composite Pattern),又叫部分整体模式,是用于把一组相似的对象当作一个单一的对象.组合模式依据树形结构来组合对象,用来表示部分以及整体层次.这种类型的设计模式属于结 ...
- 设计模式笔记(9)---组合模式(结构型)
Gof定义 将对象组合成树形结构以表示"部分--整体"的层次结构.Composite使得用户对单个对象和组合对象使用具有一致性. 在面向对象系统中,我们经常会遇到一类具有" ...
最新文章
- 学习如何用平板电脑设计和绘制自己的动漫角色
- 不可不知的软件架构模式
- 「递归」第10集 | 一款“摔”出来的产品
- [渝粤教育] 西南科技大学 电子技术基础 在线考试复习资料(1)
- (转载)分享常用的GoLang包工具
- 程序设计与算法----递归之爬楼梯问题
- 硬核黑科技告诉你,漫威十年到底有多少个角色?
- android生命周期_Android片段生命周期
- 基于OHCI的USB主机 —— USB设备其它数据结构
- java.lang.ClassCastException: com.sun.proxy.$Proxy7 cannot be cast to comms.service.message
- 任天堂被黑了!早期游戏源码及设计图大批曝光,原来塞尔达传说还有个血腥版本?
- 【老九】【C语言】CodeBlocks安装文档
- 人脸活体检测论文:Multi-Modal Face Anti-Spoofing Based on Central Difference Networks
- 在MQTT中使用SSL/TLS提高安全性
- C++之getch(),getche(),getchar()的区别
- 宽带波束形成-----恒定波束宽度设计
- 日服人物一览(按实装版本倒序)
- 常用触摸屏驱动 android
- 目标转化出价多少_头条信息流广告目标转化出价(ocpc出价)常见问题讲解
- Spring Security 鉴权流程