Scala Iterator(迭代器)不是一个集合,它是一种用于访问集合的方法。
迭代器 it 的两个基本操作是 next 和 hasNext。
调用 it.next() 会返回迭代器的下一个元素,并且更新迭代器的状态。
调用 it.hasNext() 用于检测集合中是否还有元素。
让迭代器 it 逐个返回所有元素最简单的方法是使用 while 循环:
执行以上代码,输出结果为:
$ scalac Test.scala $ scala Test Baidu Google Runoob Taobao
你可以使用 it.min 和 it.max 方法从迭代器中查找最大与最小元素,实例如下:
执行以上代码,输出结果为:
$ scalac Test.scala $ scala Test 最大元素是:90 最小元素是:2
你可以使用 it.size 或 it.length 方法来查看迭代器中的元素个数。实例如下:
执行以上代码,输出结果为:
$ scalac Test.scala $ scala Test ita.size 的值: 6 itb.length 的值: 6
下表列出了 Scala Iterator 常用的方法:
| 序号 | 方法及描述 |
|---|---|
| 1 |
def hasNext: Boolean 如果还有可返回的元素,返回true。 |
| 2 |
def next(): A 返回迭代器的下一个元素,并且更新迭代器的状态 |
| 3 |
def ++(that: => Iterator[A]): Iterator[A] 合并两个迭代器 |
| 4 |
def ++[B >: A](that :=> GenTraversableOnce[B]): Iterator[B] 合并两个迭代器 |
| 5 |
def addString(b: StringBuilder): StringBuilder 添加一个字符串到 StringBuilder b |
| 6 |
def addString(b: StringBuilder, sep: String): StringBuilder 添加一个字符串到 StringBuilder b,并指定分隔符 |
| 7 |
def buffered: BufferedIterator[A] 迭代器都转换成 BufferedIterator |
| 8 |
def contains(elem: Any): Boolean 检测迭代器中是否包含指定元素 |
| 9 |
def copyToArray(xs: Array[A], start: Int, len: Int): Unit 将迭代器中选定的值传给数组 |
| 10 |
def count(p: (A) => Boolean): Int 返回迭代器元素中满足条件p的元素总数。 |
| 11 |
def drop(n: Int): Iterator[A] 返回丢弃前n个元素新集合 |
| 12 |
def dropWhile(p: (A) => Boolean): Iterator[A] 从左向右丢弃元素,直到条件p不成立 |
| 13 |
def duplicate: (Iterator[A], Iterator[A]) 生成两个能分别返回迭代器所有元素的迭代器。 |
| 14 |
def exists(p: (A) => Boolean): Boolean 返回一个布尔值,指明迭代器元素中是否存在满足p的元素。 |
| 15 |
def filter(p: (A) => Boolean): Iterator[A] 返回一个新迭代器 ,指向迭代器元素中所有满足条件p的元素。 |
| 16 |
def filterNot(p: (A) => Boolean): Iterator[A] 返回一个迭代器,指向迭代器元素中不满足条件p的元素。 |
| 17 |
def find(p: (A) => Boolean): Option[A] 返回第一个满足p的元素或None。注意:如果找到满足条件的元素,迭代器会被置于该元素之后;如果没有找到,会被置于终点。 |
| 18 |
def flatMap[B](f: (A) => GenTraversableOnce[B]): Iterator[B] 针对迭代器的序列中的每个元素应用函数f,并返回指向结果序列的迭代器。 |
| 19 |
def forall(p: (A) => Boolean): Boolean 返回一个布尔值,指明 it 所指元素是否都满足p。 |
| 20 |
def foreach(f: (A) => Unit): Unit 在迭代器返回的每个元素上执行指定的程序 f |
| 21 |
def hasDefiniteSize: Boolean 如果迭代器的元素个数有限则返回 true(默认等同于 isEmpty) |
| 22 |
def indexOf(elem: B): Int 返回迭代器的元素中index等于x的第一个元素。注意:迭代器会越过这个元素。 |
| 23 |
def indexWhere(p: (A) => Boolean): Int 返回迭代器的元素中下标满足条件p的元素。注意:迭代器会越过这个元素。 |
| 24 |
def isEmpty: Boolean 检查it是否为空, 为空返回 true,否则返回false(与hasNext相反)。 |
| 25 |
def isTraversableAgain: Boolean Tests whether this Iterator can be repeatedly traversed. |
| 26 |
def length: Int 返回迭代器元素的数量。 |
| 27 |
def map[B](f: (A) => B): Iterator[B] 将 it 中的每个元素传入函数 f 后的结果生成新的迭代器。 |
| 28 |
def max: A 返回迭代器迭代器元素中最大的元素。 |
| 29 |
def min: A 返回迭代器迭代器元素中最小的元素。 |
| 30 |
def mkString: String 将迭代器所有元素转换成字符串。 |
| 31 |
def mkString(sep: String): String 将迭代器所有元素转换成字符串,并指定分隔符。 |
| 32 |
def nonEmpty: Boolean 检查容器中是否包含元素(相当于 hasNext)。 |
| 33 |
def padTo(len: Int, elem: A): Iterator[A] 首先返回迭代器所有元素,追加拷贝 elem 直到长度达到 len。 |
| 34 |
def patch(from: Int, patchElems: Iterator[B], replaced: Int): Iterator[B] 返回一个新迭代器,其中自第 from 个元素开始的 replaced 个元素被迭代器所指元素替换。 |
| 35 |
def product: A 返回迭代器所指数值型元素的积。 |
| 36 |
def sameElements(that: Iterator[_]): Boolean 判断迭代器和指定的迭代器参数是否依次返回相同元素 |
| 37 |
def seq: Iterator[A] 返回集合的系列视图 |
| 38 |
def size: Int 返回迭代器的元素数量 |
| 39 |
def slice(from: Int, until: Int): Iterator[A] 返回一个新的迭代器,指向迭代器所指向的序列中从开始于第 from 个元素、结束于第 until 个元素的片段。 |
| 40 |
def sum: A 返回迭代器所指数值型元素的和 |
| 41 |
def take(n: Int): Iterator[A] 返回前 n 个元素的新迭代器。 |
| 42 |
def toArray: Array[A] 将迭代器指向的所有元素归入数组并返回。 |
| 43 |
def toBuffer: Buffer[B] 将迭代器指向的所有元素拷贝至缓冲区 Buffer。 |
| 44 |
def toIterable: Iterable[A] Returns an Iterable containing all elements of this traversable or iterator. This will not terminate for infinite iterators. |
| 45 |
def toIterator: Iterator[A] 把迭代器的所有元素归入一个Iterator容器并返回。 |
| 46 |
def toList: List[A] 把迭代器的所有元素归入列表并返回 |
| 47 |
def toMap[T, U]: Map[T, U] 将迭代器的所有键值对归入一个Map并返回。 |
| 48 |
def toSeq: Seq[A] 将代器的所有元素归入一个Seq容器并返回。 |
| 49 |
def toString(): String 将迭代器转换为字符串 |
| 50 |
def zip[B](that: Iterator[B]): Iterator[(A, B) 返回一个新迭代器,指向分别由迭代器和指定的迭代器 that 元素一一对应而成的二元组序列 |
更多方法可以参考 API文档
我在用Ruby执行简单任务时遇到了一件奇怪的事情。我只想用每个方法迭代字母表,但迭代在执行中先进行:alfawit=("a".."z")puts"That'sanalphabet:\n\n#{alfawit.each{|litera|putslitera}}"这段代码的结果是:(缩写)abc⋮xyzThat'sanalphabet:a..z知道为什么它会这样工作或者我做错了什么吗?提前致谢。 最佳答案 因为您的each调用被插入到在固定字符串之前执行的字符串文字中。此外,each返回一个Enumerable,实际上您甚至打印它。试试
我最近开始编写Ruby代码,但我对block参数有误解。以下面的代码为例:h={#Ahashthatmapsnumbernamestodigits:one=>1,#The"arrows"showmappings:key=>value:two=>2#ThecolonsindicateSymbolliterals}h[:one]#=>1.Accessavaluebykeyh[:three]=3#Addanewkey/valuepairtothehashh.eachdo|key,value|#Iteratethroughthekey/valuepairsprint"#{value}:#{ke
我想从特定索引开始遍历数组。我该怎么做?myj.eachdo|temp|...end 最佳答案 执行以下操作:your_array[your_index..-1].eachdo|temp|###end 关于ruby-从特定索引开始迭代数组,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/44151758/
我正在用ruby遍历一个数组。有没有一种简单的方法可以在不返回for循环的情况下获取迭代次数或数组索引? 最佳答案 啊,知道了。each_with_index哇!编辑:糟糕! 关于ruby-如何使用每个迭代器获取数组索引或迭代次数?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/706115/
我在阅读有关.each迭代器的Ruby问题,有人说如果更高阶的迭代器更适合该任务,则使用.each可能会产生代码味道。Ruby中的高阶迭代器是什么?编辑:我提到的StackOverflow答案的作者JörgWMittag提到他是要编写更高级别的迭代器,但他还解释了下面的内容。 最佳答案 哎呀。我的意思是更高级别的迭代器,而不是更高阶的迭代器。当然,每个迭代器都是高阶的。基本上,迭代是一个非常低级的概念。编程的目的是与团队中的其他利益相关者交流意图。“初始化一个空数组,然后遍历另一个数组,并将该数组的当前元素添加到第一个数组中(如果该
我的背景是PHP和C#,但我真的很想学习RoR。为此,我开始阅读官方文档。我对一些代码示例有一些疑问。第一个是迭代器:classArraydefinject(n)each{|value|n=yield(n,value)}nenddefsuminject(0){|n,value|n+value}enddefproductinject(1){|n,value|n*value}endend我理解yield的意思是“在这里执行关联的block”。令我震惊的是|value|n=each的一部分。其他block对我来说更有意义,因为它们似乎模仿C#风格的lambda:publicintsum(in
我知道我可以用这段代码迭代liquid模板中的数组:{%foriteminmyarray%}{{item.label}}但是我怎样才能得到我的项目在数组中的索引呢? 最佳答案 根据"LiquidforDesigners"liquid的github部分...forloop.length#=>lengthoftheentireforloopforloop.index#=>indexofthecurrentiterationforloop.index0#=>indexofthecurrentiteration(zerobased)forl
我在使用Ruby时遇到了初期问题,涉及创建单向、惰性求值、可能无限的迭代器。基本上,我尝试像使用Haskell列表一样使用Ruby,并在较小程度上使用Python生成器。并不是我不理解它们本身;而是我不理解它们。我只是不知道如何像其他语言一样随意使用它们,而且我也不确定Ruby中的哪些方法会在我背后将它们变成数组,从而不必要地将整个序列卸载到内存中。是的,我一直在研究Ruby引用手册。实际上,专心地进行了半个小时。或许显然不是。例如,如果我要实现一个卡片组,它在Python中看起来像这样(未经测试):#Python3fromitertoolsimportchain,countface_
有没有一种简单的说法:否则,如果没有任何循环,则显示“无对象”。似乎应该有一个很好的语法方法来执行此操作而不是计算@user.find_object("param")的长度 最佳答案 你可以这样做:if@collection.blank?#@collectionwasemptyelse@collection.eachdo|object|#Youriterationlogicendend 关于ruby-on-rails-在RubyonRails的每个循环中,如果没有任何迭代,是否有做某事的
我到处寻找优雅的解决方案。本质问题似乎是映射到数据库列的ActiveRecord属性在ActiveRecord::Base中的处理方式与attr_accessor方法完全不同。我想做这样的事情:model.attribute_names.eachdo|name|#dostuffend在某种程度上也包括attr_accessor字段,但不包括任何其他实例方法。我知道这不是内置的,但最优雅的方法是什么? 最佳答案 你无法真正解决这个问题。您可以近似破解,但它永远不会很好地工作。model.attribute_names应该给你所有的Ac