gpt4 book ai didi

scala - 为什么 TraversableOnce.toSeq 返回一个流?

转载 作者:行者123 更新时间:2023-12-04 14:44:19 29 4
gpt4 key购买 nike

下面是一个例子:

scala> val xs = List(1,2,3).toIterator.toSeq
xs: Seq[Int] = Stream(1, ?)

序列是一个物化集合(默认是 List),所以我预计是 toSeq将返回 List ,不是 Stream
实现是在 TraversableOnce 中,
  def toSeq: Seq[A] = toStream

为什么它没有在 TraversableLike 中被覆盖?

最佳答案

Scala 支持无限迭代器,而 Stream是最简单的Seq对于可能的无限数据。

Iterator.from(1).toSeq

终止(如果只使用了集合的一部分),但是
Iterator.from(1).toList

永远不会终止。

如果一个同样有效的决定不会,你不想破坏代码。 toSeq方法不知道迭代器的起源,因此它必须假设它可以是无限的。

文档“解释”这个决定是这样的:

Converts this traversable or iterator to a sequence. As with toIterable, it's lazy in this default implementation, as this TraversableOnce may be lazy and unevaluated. Note: will not terminate for infinite-sized collections.



http://www.scala-lang.org/api/current/?_ga=1.200291566.1390086478.1406220121#scala.collection.Iterator

关于scala - 为什么 TraversableOnce.toSeq 返回一个流?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26432144/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com