设计模式之组合模式,component

package liu.composite.demo;
public abstract class Component {
 public String name;
 public Component(String name){
  this.name = name;
 }
 public Component(){
  
 }
 
 public abstract void add(Component c);
 public abstract void remove(Component c);
 public abstract void display(int depth);
}
-----------------------------
package liu.composite.demo;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
public class Composite extends Component {
 public Composite(String name){
  super(name);
 }
 
 private List<Component> children = new ArrayList<Component>();
 @Override
 public void add(Component c) {
  children.add(c);
  
 }
 @Override
 public void remove(Component c) {
  children.remove(c);
  
 }
 @Override
 public void display(int depth) {
  for(int i = 0 ;i<depth;i++)
   System.out.print("-");
  System.out.println(name);
  
  for(Iterator tmp = children.iterator();tmp.hasNext();){
   ((Component) tmp.next()).display(depth+2);
   //System.out.println();
  }
  
 }
}
---------------------------
package liu.composite.demo;
public class Leaf extends Component {
 public Leaf(String name){
  super(name);
 }
 @Override
 public void add(Component c) {
  System.out.println("can not add to a leaf");
  
 }
 @Override
 public void remove(Component c) {
  System.out.println("can remove from a leaf");
  
 }
 @Override
 public void display(int depth) {
  for(int i = 0 ;i<depth;i++)
   System.out.print("-");
  System.out.println(name);
  
 }
}
----------------------------------
package liu.composite.demo;
public class Main {
 public static void main(String[] args) {
  Composite root = new Composite("root");
  root.add(new Leaf("Leaf A"));
  root.add(new Leaf("Leaf B"));
  
  Composite comp = new Composite("Composite x");
  comp.add(new Leaf("Leaf XA"));
  comp.add(new Leaf("Leaf XB"));
  root.add(comp);
  
  Composite comp2 = new Composite("Composite xy");
  comp2.add(new Leaf("Leaf XYA"));
  comp2.add(new Leaf("Leaf XYB"));
  comp.add(comp2);
  root.add(new Leaf("Leaf C"));
  Leaf leaf = new Leaf("Leaf D");
  root.add(leaf);
  root.remove(leaf);
  root.display(1);
  
 }
}
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值