边肖将与您分享如何在java中实现迭代器模式。相信大部分人还不太了解,所以分享这篇文章给大家参考。希望你看完这篇文章会有很多收获。我们一起来看看吧!
迭代器模式
迭代器模式用于在不知道集合对象的底层表示的情况下顺序访问集合对象的元素。诸如Java和。Net已经使用迭代器作为内部语法元素。例如,在C#中,集合对象只需要实现IEnumberable接口,然后foreach就可以遍历它们。迭代器模式提示我们考虑如何设计接口,以及如何从用户的角度提供对内部对象的外部访问。即使我们组织的对象系统内部结构非常复杂,客户端程序最简单的方式就是依次遍历for /foreach循环,遍历过程中的顺序、分类、过滤都是由目标类型本身封装的。
GOF对迭代器模式描述为:提供一种方法来顺序访问聚合对象的元素,而不暴露其底层表示。—设计模式:可重用面向对象软件的元素
UML类图:
代码实现
//迭代器接口
公共接口迭代端口
{
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