打字猴:1.700468472e+09
1700468472
1700468473 //创建一个根节点
1700468474
1700468475 Composite root=new Composite();
1700468476
1700468477 root.doSomething();
1700468478
1700468479 //创建一个树枝构件
1700468480
1700468481 Composite branch=new Composite();
1700468482
1700468483 //创建一个叶子节点
1700468484
1700468485 Leaf leaf=new Leaf();
1700468486
1700468487 //建立整体
1700468488
1700468489 root.add(branch);
1700468490
1700468491 branch.add(leaf);
1700468492
1700468493 }
1700468494
1700468495 //通过递归遍历树
1700468496
1700468497 public static void display(Composite root){
1700468498
1700468499 for(Component c:root.getChildren()){
1700468500
1700468501 if(c instanceof Leaf){//叶子节点
1700468502
1700468503 c.doSomething();
1700468504
1700468505 }else{//树枝节点
1700468506
1700468507 display((Composite)c);
1700468508
1700468509 }
1700468510
1700468511 }
1700468512
1700468513 }
1700468514
1700468515 }
1700468516
1700468517 各位可能已经看出一些问题了,组合模式是对依赖倒转原则的破坏,但是它还有其他类型的变形,面向对象就是这么多的形态和变化,请读者继续阅读下去,就会找到解决方案。
1700468518
1700468519
1700468520
1700468521
[ 上一页 ]  [ :1.700468472e+09 ]  [ 下一页 ]