学与技术","test"));
softwareCollege.add(new Department("大数据科学与技术","test"));
university.add(infoProjectCollege);
university.add(softwareCollege);
university.print();
}
}
组合模式在JDK集合应用
HashMap中使用了组合模式
//说明
//1.Map就是一个抽象的构建(类似我们的Component)
//2. HashMap是一个中间的构建(Composite),实现/继承了相关方法put,putAll
//3. Node是 HashMap的静态内部类,类似Leaf叶子节点,这里就没有put,putAll
// static class Node<K,V> implements Map.Entry<K,vl
注意事项和细节
- 1.简化客户端操作。客户端只需要面对一致的对象而不用考虑整体部分或者节点叶子的问题。
- 2.具有较强的扩展性。当我们要更改组合对象时,我们只需要调整内部的层次关系,客户端不用做出任何改动。
- 3.方便创建出复杂的层次结构。客户端不用理会组合里面的组成细节,容易添加节点或者叶子从而创建出复杂的树形结构。
- 4.需要遍历组织机构,或者处理的对象具有树形结构时,非常适合使用组合模式。
- 5.要求较高的抽象性,如果节点和叶子有很多差异性的话,比如很多方法和属性都不一样,不适合使用组合模式。
只是为了记录自己的学习历程,且本人水平有限,不对之处,请指正。