1.composite模式意在组成任意复杂度的整体--部分组件层次结构,同时将单个组件或复合组件视为统一的接口。树形组织结构就是其中一种表现形式。
作者:中国IT实验室 来源:中国IT实验室 2007年8月26日
关键字:
Disk是组合体内的一个对象,或称一个部件,这个部件是个单独元素( Primitive)。
Disk.java:
- package implEquip;
-
- import com.interf.Equipment;
-
- public class Disk extends Equipment {
-
- public Disk(String name) {
- super(name);
- // TODO Auto-generated constructor stub
- }
-
- //定义Disk实价为1
- public double netPrice() {
- return 1.;
- }
- //定义了disk折扣价格是0.5 对折。
- public double discountPrice() {
- return .5;
- }
- }
还有一种可能是,一个部件也是一个组合体,就是说这个部件下面还有'儿子',这是树形结构中通常的情况,应该比较容易理解。现在我们先要定义这个组合体:
CompsiteEquipment.java:
- package implEquip;
-
- import java.util.ArrayList;
- import java.util.Iterator;
- import java.util.List;
- import java.util.NoSuchElementException;
-
- import com.interf.Equipment;
-
- public class CompositeEquipment extends Equipment {
-
- private int i=0;
- // 定义一个Vector 用来存放'儿子'
- private List equipment = new ArrayList();
-
- public CompositeEquipment(String name) {
- super(name);
- // TODO Auto-generated constructor stub
- }
-
-
- public boolean add(Equipment equipment) {
- this.equipment.add(equipment);
- return true;
- }
- public double netPrice() {
- double netPrice=0.;
- Iterator iter=equipment.iterator();
- while(iter.hasNext())
- netPrice+=((Equipment)iter.next()).netPrice();
- return netPrice;
- }
-
- public double discountPrice() {
- double discountPrice=0.;
- Iterator iter=equipment.iterator();
- while(iter.hasNext())
- discountPrice+=((Equipment)iter.next()).discountPrice();
- return discountPrice;
- }
-
- // 注意这里,这里就提供用于访问自己组合体内的部件方法。
- // 上面dIsk 之所以没有,是因为Disk是个单独(Primitive)的元素.
- public Iterator iter() {
- return equipment.iterator() ;
- }
- // 重载Iterator方法
- public boolean hasNext() { return i<equipment.size(); }
- // 重载Iterator方法
- public Object next(){
- if(hasNext())
- return equipment.get(i++);
- else
- throw new NoSuchElementException();
- }
- }