• 【软件设计模式之迭代器与组合模式】


    前言

    迭代器模式主要用于顺序访问集合中的元素,而不需要了解底层的实现细节。它为遍历不同的集合结构提供了一种统一的接口。这种模式在实际开发中广泛应用于各种集合类的设计中,如列表、树结构和图结构。

    组合模式则用于处理对象的部分-整体层次结构。通过将对象组织成树形结构,它能够让我们统一对待单个对象和组合对象。这种模式在设计具有层级结构的系统时特别有用,如图形界面组件的设计、文件系统的结构等。

    一、迭代器模式

    1. 迭代器模式定义

    迭代器模式是一种行为型设计模式,它提供了一种方法来顺序访问聚合对象中的各个元素,而又无需暴露该对象的内部表示。这种模式的主要目的是封装集合对象的内部结构,提供一种统一的方法来迭代这些对象,从而简化外部界面与集合之间的交互。

    2. 应用场景

    • 访问聚合对象内容而不暴露其内部细节: 迭代器允许外部代码透明地访问聚合的元素,而无需知道其内部结构(如数组、链表等)。
    • 支持多种遍历方式: 迭代器模式可以实现多种遍历算法,使得相同的聚合对象可以用不同的遍历方式来遍历。
    • 统一的接口: 为不同的聚合结构(如列表、树等)提供一个统一的接口,使得外部代码不必关心具体的聚合结构,从而更容易扩展和维护。

    3. 实现示例

    // 定义迭代器接口
    public interface Iterator {
        boolean hasNext();
        Object next();
    }
    
    // 实现具体的迭代器
    public class ConcreteIterator implements Iterator {
        private Collection collection;
        private int currentIndex = 0;
    
        public ConcreteIterator(Collection collection) {
            this.collection = collection;
        }
    
        @Override
        public boolean hasNext() {
            return currentIndex < collection.size();
        }
    
        @Override
        public Object next() {
            if (this.hasNext()) {
                return collection.get(currentIndex++);
            }
            return null;
        }
    }
    
    // 使用迭代器的集合接口
    public interface Collection {
        Iterator createIterator();
        // 其他集合相关方法...
    }
    
    // 具体的集合类
    public class ConcreteCollection implements Collection {
        private List<Object> items = new ArrayList<>();
    
        // 实现创建迭代器的方法
        @Override
        public Iterator createIterator() {
            return new ConcreteIterator(this);
        }
    
        // 其他集合相关方法...
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47

    在这个例子中,Iterator 接口定义了迭代器的基本功能,ConcreteIterator 是具体的迭代器实现,它与一个具体的集合(如 ConcreteCollection)相关联。通过这种方式,集合的内部表示对于使用迭代器的代码来说是透明的,从而实现了迭代器模式的核心目标:分离集合对象的遍历行为和实现细节。

    二、组合模式

    1. 组合模式定义

    组合模式是一种结构型设计模式,允许将对象组合成树形结构以表示部分整体层次结构。这种模式让用户可以以统一的方式处理单个对象和对象的组合。组合模式使得客户能够忽略对象组合和单个对象的差异,统一地使用它们。

    2. 应用场景

    • 处理树状结构: 当开发者希望统一处理简单和复杂元素时,例如文件系统中的文件和文件夹。
    • 忽略差异: 当客户端可以忽略组合对象和单个对象的差异,并以同样的方式处理它们时。
    • 统一的接口: 提供一个统一的接口来访问个别对象以及对象的组合,使得客户端代码在处理单个对象和组合对象时更加简洁。

    3. 实现示例

    // 抽象组件类
    public abstract class Component {
        public void add(Component component) {
            throw new UnsupportedOperationException();
        }
    
        public void remove(Component component) {
            throw new UnsupportedOperationException();
        }
    
        public Component getChild(int i) {
            throw new UnsupportedOperationException();
        }
    
        public abstract void operation();
    }
    
    // 叶子节点类
    public class Leaf extends Component {
        private String name;
    
        public Leaf(String name) {
            this.name = name;
        }
    
        @Override
        public void operation() {
            System.out.println("Leaf " + name + ": operation");
        }
    }
    
    // 组合类
    public class Composite extends Component {
        private List<Component> children = new ArrayList<>();
        private String name;
    
        public Composite(String name) {
            this.name = name;
        }
    
        @Override
        public void add(Component component) {
            children.add(component);
        }
    
        @Override
        public void remove(Component component) {
            children.remove(component);
        }
    
        @Override
        public Component getChild(int i) {
            return children.get(i);
        }
    
        @Override
        public void operation() {
            System.out.println("Composite " + name + ": operation");
            for (Component child : children) {
                child.operation();
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63

    在这个示例中,Component 是抽象基类,定义了所有组件的共有行为。Leaf 表示叶子节点,没有子组件。Composite 表示容器节点,可以包含其他叶子节点或容器节点。这样的设计允许客户端代码以统一的方式处理单个对象和复合对象。

    三、迭代器与组合模式的结合应用

    1. 综合应用场景

    • 构建和遍历树形结构: 使用组合模式构建树形或分层的对象结构,如图形用户界面元素、文件系统等。随后,利用迭代器模式遍历这些结构,实现对整个结构或部分结构的有效操作。
    • 统一接口访问: 在组合模式构建的层次结构中,迭代器模式提供了一个统一的接口来遍历和访问各个元素,无论它们是简单的叶节点还是复杂的组合节点。
    • 分离复杂结构的创建和操作: 组合模式专注于构建复杂的对象集合,而迭代器模式专注于这些集合的遍历和操作,这种分离使得两者更加专注且高效。

    2. 结合使用的优势

    • 易于管理复杂的树形结构: 组合模式使得树形结构的构建变得简单和直观,而迭代器模式则使得遍历这些结构变得容易,尤其是在不需要了解底层细节的情况下。
    • 提高代码的复用性和扩展性: 这种结合允许开发者编写更通用的代码来处理集合对象,无论其内部结构如何。这种方法提高了代码的复用性,并使得新增元素或改变集合结构变得更加容易。
    • 简化客户端代码: 客户端代码可以统一地使用迭代器来遍历集合,无论它是单个对象还是复杂的组合对象。这简化了客户端代码并提高了其清晰度。

    总结

    迭代器模式提供了一种有效的方式来顺序访问聚合对象中的元素,同时隐藏了底层数据结构的复杂性。这种模式的主要优势在于它支持多种遍历方式,并能够为不同的数据结构提供一个统一的迭代接口。它使得客户代码可以在不了解或不关心底层数据结构的情况下,遍历一个聚合对象中的所有元素。

    组合模式则是一种结构型设计模式,它允许将对象组织成树形结构,以表示整体与部分的关系。这种模式非常适用于那些需要表达和操作分层或树形结构的场合。它让客户能以统一的方式处理单个对象和对象组合,极大地简化了对复杂结构的操作。

  • 相关阅读:
    【Mybatis编程:批量插入相册(动态SQL)】
    kafka学习
    第九章 常用服务器的搭建
    在线协作文档哪家强?微软 Loop 、Notion、FlowUs
    Centos7.9 安装 clickhouse 24.6.1
    js函数调用的方式有几种
    C++第二课(数据类型)
    数据结构——链表
    Qt中各个功能模块遵循的协议
    链表——反转链表
  • 原文地址:https://blog.csdn.net/qq_66726657/article/details/136226196