1.将对象组合成树形结构以表示‘部分-整体’的层次结构。组合模式使得用户对单个对象和组合对象的使用具有一致性。”
当发现需求中是体现部分与整体层次结构时,以及你希望用户可以忽略组合对象与单个对象的不同,统一地使用组合结构中的所有对象时,就应该考虑组合模式了。
就拿剪发办卡的事情来分析一下吧。
首先,一张卡可以在总部,分店,加盟店使用,那么总部可以刷卡,分店也可以刷卡,加盟店也可以刷卡,这个属性结构的店面层级关系就明确啦。
那么,总店刷卡消费与分店刷卡消费是一样的道理,那么总店与分店对会员卡的使用也具有一致性。
那么我们就根据我们会员卡的消费,来模拟一下组合模式的实现吧!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();
}
}
2.
3.