java中的迭代器模式怎么实现

技术java中的迭代器模式怎么实现小编给大家分享一下java中的迭代器模式怎么实现,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!迭代器模式迭代

边肖将与您分享如何在java中实现迭代器模式。相信大部分人还不太了解,所以分享这篇文章给大家参考。希望你看完这篇文章会有很多收获。我们一起来看看吧!

迭代器模式

迭代器模式用于在不知道集合对象的底层表示的情况下顺序访问集合对象的元素。诸如Java和。Net已经使用迭代器作为内部语法元素。例如,在C#中,集合对象只需要实现IEnumberable接口,然后foreach就可以遍历它们。迭代器模式提示我们考虑如何设计接口,以及如何从用户的角度提供对内部对象的外部访问。即使我们组织的对象系统内部结构非常复杂,客户端程序最简单的方式就是依次遍历for /foreach循环,遍历过程中的顺序、分类、过滤都是由目标类型本身封装的。

GOF对迭代器模式描述为:提供一种方法来顺序访问聚合对象的元素,而不暴露其底层表示。—设计模式:可重用面向对象软件的元素

UML类图:java中的迭代器模式怎么实现

代码实现

//迭代器接口

公共接口迭代端口

{

TNext();

boolHasNext();

}

//具体迭代器

public class concrete iterators : iiterorart

{

privateConcreteAggretateTAggretate//成员变量,关联关系

private intcursor=0;

公共混凝土迭代器

{

这个。Aggretate=agg

}

publicboolHasNext()

{

回来!(光标=聚合状态。大小);

}

publicTNext()

{

if(HasNext())

{

returnAggretate。GetELement(光标);

}

其他

{

返回默认值;

}

}

}

//聚合接口

publicationinterfaceiaggreatet

{

sp;public void Add(T obj);
    public void Remove(T obj);
    public int Size { get; }
    public T GetELement(int index);
    public IIterator<T> GetIterator();
}
//具体聚合
public class ConcreteAggretate<T> : IAggretate<T>
{
    private List<T> list = new List<T>();  //
    public void Add(T obj)
    {
        list.Add(obj);
    }
    public void Remove(T obj)
    {
        list.Remove(obj);
    }
    public IIterator<T> GetIterator()
    {
        return new ConcreteIterator<T>(this);  //在局部方法中new实例,属依赖关系
    }
    public int Size
    {
        get
        {
            return list.Count;
        }
    }
    public T GetELement(int index)
    {
        return list[index];
    }
}

调用者代码:

IAggretate<int> aggretate = new ConcreteAggretate<int>();
aggretate.Add(9);
aggretate.Add(8);
aggretate.Add(7);
IIterator<int> iterator = aggretate.GetIterator();
while (iterator.HasNext())
{
    Console.WriteLine(iterator.Next());
}

基于IEnumerable的实现

以上便是经典的迭代器模式的实现,这种模式给聚合对象增加了一个创建其迭代器对象的方法,迭代器的抽象定义和具体迭代器类型都作为一个额外的对象存在。 实际上C#已内置了对迭代器模式的支持,只需要实现IEnumerable接口即可,不再需要从0开始,少了很多代码量:

public class ConcreteAggretate<T> : IEnumerable<T>
{
    private List<T> list = new List<T>();
    public void Add(T obj)
    {
        list.Add(obj);
    }
    public void Remove(T obj)
    {
        list.Remove(obj);
    }
    public IEnumerator<T> GetEnumerator()
    {
        foreach (var item in list)
        {
            yield return item;
        }
    }
    IEnumerator IEnumerable.GetEnumerator()
    {
        throw new NotImplementedException();
    }
}

使用foreach遍历IEnumerable接口

var aggretate = ConcreteAggretate<int>();
aggretate.Add(9);
aggretate.Add(8);
aggretate.Add(7);
foreach (var item in aggretate)
{
    Console.WriteLine(item);
}

使用场景

  • 对象内部结构比较复杂,为了让调用者可以轻松地访问,同时不需要暴露其内部结构;

  • 需要为聚合对象提供多种遍历方式;

  • 为遍历不同的聚合结构提供一个统一的接口;

迭代器模式的优缺点

优点

  • 迭代器支持以不同的方式遍历一个聚合对象,而且在同一个聚合上可以添加多个具有不同遍历方式的迭代器;

  • 迭代器简化了聚合类的遍历;

  • 迭代器模式可以方便地增加新的聚合类和迭代器类,无须修改原有代码。

缺点 迭代器模式通过将存储数据和遍历数据的职责分离,为封装集合地复杂性、隔离变化提供了极大的遍历,但这种方式也有其固有的缺点:每次 增加新的聚合类都需要对应增加新的迭代器类,类的个数成对增加,这在一定程度上增加了系统的复杂性。

以上是“java中的迭代器模式怎么实现”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/98525.html

(0)

相关推荐

  • DNS访问原理是什么

    技术DNS访问原理是什么DNS访问原理是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。前两天遇到一个面试的小伙伴,他说面试官和他聊得很投机,无意中谈

    攻略 2021年12月3日
  • 怎么用Python来统计知识星球打卡作业

    技术怎么用Python来统计知识星球打卡作业本篇内容主要讲解“怎么用Python来统计知识星球打卡作业”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用Python来统计知

    攻略 2021年11月29日
  • css如何设置链接点击后的颜色

    技术css如何设置链接点击后的颜色这篇文章主要为大家展示了“css如何设置链接点击后的颜色”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css如何设置链接点击后的颜色”这篇文

    攻略 2021年12月10日
  • 计算机中即可作为输入设备又可以作为输出设备的是什么

    技术计算机中即可作为输入设备又可以作为输出设备的是什么这篇文章主要讲解了“计算机中即可作为输入设备又可以作为输出设备的是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“

    攻略 2021年11月8日
  • 373. 查找和最小的K对数字

    技术373. 查找和最小的K对数字 373. 查找和最小的K对数字给定两个以升序排列的整数数组 nums1 和 nums2,以及一个整数 k。
    定义一对值(u,v),其中第一个元素来自nums1,第二个

    礼包 2021年12月16日
  • activity流程id存在哪张表(两个activity之间跳转执行什么方法)

    技术Activity的singleTask怎么使用这篇文章主要讲解了“Activity的singleTask怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Acti

    攻略 2021年12月18日