迭代器的基本方法 什么是迭代器?
什么是迭代器?
简介:迭代器,有时称为游标,是一种程序设计的软件设计模式。它是一个可以在整个容器(如链表或数组)中访问的接口。设计者不需要关心容器的内容。
1. 函数:iterator使开发人员能够在类或结构中支持foreach迭代,而无需实现IEnumerable或ienumerator接口。只需提供一个迭代器来遍历类中的数据结构。当编译器检测到迭代器时,它将自动生成IEnumerable接口或ienumerator接口的current、MoveNext和dispose方法。
2. 特点:(1)迭代器是一段代码,可以返回相同类型的有序值序列。(2) 迭代器可以用作方法、运算符或get访问器的代码体。(3) 迭代器代码使用yield return语句依次返回每个元素,yield break终止迭代。(4) 可以在一个类中实现多个迭代器。每个迭代器必须像任何类成员一样具有唯一的名称,并且可以由客户机在foreach语句中调用。代码如下:foreach(int x in)SimpleClass.Iterator2){}。(5)迭代器的返回类型必须是IEnumerable或ienumerator。
java中foreach和迭代器在遍历List集合,一些情况下为什么能使用集合自动的删除方法删除元素?
当您是<70时,倒数第二位是66。您没有引发异常,因为以前的列表大小是5。删除66后,列表大小为4。第一次遍历列表大小为5的数组时,指针66位于index=4中。遍历列表大小为4的数组时,指针66位于index=4中newlist.size文件()。
ArrayList中的此方法将判断列表已被读取,因此不会引发异常。
1]]2
3
公共布尔hasnext(){
返回光标!=size
}
A< 90,第二位变了,列表的大小也变了
看ArrayList的源代码,调用这个方法检查列表的大小是否每次都变,但是这个方法发生在hasnext方法之后
1
2
3
4
final void Checkforcomodification(){
if(modcount!=expectedmodcount)
抛出新的并发修改异常()
什么是迭代器iterator?
迭代器
迭代器是一种设计模式。它是一个可以遍历和选择序列中的对象的对象,开发人员不需要了解序列的底层结构。
迭代器通常被称为“轻量级”对象,因为它们的创建成本很低。Java中的迭代器函数相对简单,只能向一个方向移动:
(1)iterator()方法要求容器返回迭代器。第一次调用迭代器的next()方法时,它返回序列的第一个元素。
注意:iterator()方法是java.lang.Iterable语言接口,由集合继承。
(2)使用next()获取序列中的下一个元素。
(3)使用hasnext()检查序列中是否还有元素。
(4)使用remove()删除迭代器新返回的元素。
Iterator是Java Iterator最简单的实现。为列表设计的Listiterator有更多的函数。它可以从两个方向遍历列表,还可以从列表中插入和删除元素。
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。