当我们需要处理树形结构数据时,组合模式(Composite Pattern)就会变得非常有用。组合模式允许我们将对象组合成树形结构来表示“整体/部分”的层次结构,使得客户端可以统一地处理单个对象和组合对象。
在组合模式中,我们通常会定义一个抽象类或者接口来表示对象,可能会包含添加、删除、遍历子对象等方法。对于叶子节点而言,它们通常是无法再添加子节点了,所以它们的这些方法可以是空实现。
具体的组合对象可以是一个复合对象,里面包含一些基本对象作为它的子节点(例如文件夹包含了多个文件),也可以是其他复合对象作为它的子节点。最终,树形结构的层数可以非常深,但是我们只需要通过调用根节点的方法来处理整棵树。
使用组合模式可以让代码更加灵活,易于扩展,同时也可以提高代码的可读性和可维护性。
示例代码:
interface Component {
void operation();
}
class Leaf implements Component {
public void operation() {
System.out.println("Leaf operation");
}
}
class Composite implements Component {
private List<Component> children = new ArrayList<Component>();
public void add(Component component) {
children.add(component);
}
public void remove(Component component) {
children.remove(component);
}
public void operation() {
for (Component component : children) {
component.operation();
}
}
}
public class Client {
public static void main(String[] args) {
Component leaf1 = new Leaf();
Component leaf2 = new Leaf();
Composite composite1 = new Composite();
composite1.add(leaf1);
composite1.add(leaf2);
Component leaf3 = new Leaf();
Component leaf4 = new Leaf();
Composite composite2 = new Composite();
composite2.add(leaf3);
composite2.add(leaf4);
composite2.add(composite1);
composite2.operation();
}
}
调用composite2.operation()方法时,整个树形结构的操作将会被执行。
标签:Leaf,组合,void,Component,模式,add,树形,new,operation From: https://www.cnblogs.com/li053/p/17353497.html