我理解Ruby和Python的让步。Scala的yield做了什么?
发布于 2009-06-27 09:42:20
它在sequence comprehensions中使用(就像Python的列表理解和生成器一样,您也可以在其中使用yield
)。
它与for
结合使用,并将一个新元素写入结果序列中。
简单示例(来自scala-lang)
/** Turn command line arguments to uppercase */
object Main {
def main(args: Array[String]) {
val res = for (a <- args) yield a.toUpperCase
println("Arguments: " + res.toString)
}
}
在F#中对应的表达式为
[ for a in args -> a.toUpperCase ]
或
from a in args select a.toUpperCase
在Linq.
Ruby的yield
有不同的效果。
发布于 2009-06-27 09:52:59
除非您从Scala用户那里得到更好的答案(我不是),以下是我的理解。
它仅显示为以for
开头的表达式的一部分,该表达式说明如何从现有列表生成新列表。
类似于:
var doubled = for (n <- original) yield n * 2
因此,每个输入都有一个输出项(尽管我相信有一种方法可以删除重复项)。
这与其他语言中的“命令式延续”有很大不同,在其他语言中,它提供了一种方法,可以从几乎任何结构的一些命令式代码生成任意长度的列表。
(如果您熟悉C#,那么它更接近LINQ's select
operator,而不是yield return
)。
发布于 2018-08-12 20:02:32
next类似于for循环,它有一个我们看不到的缓冲区,对于每个增量,它不断向缓冲区添加下一项。当for循环结束运行时,它将返回所有产出值的集合。Yield可以用作简单的算术运算符,甚至可以与数组结合使用。这里有两个简单的例子,可以让你更好地理解
scala>for (i <- 1 to 5) yield i * 3
res: scala.collection.immutable.IndexedSeqInt =向量(3,6,9,12,15)
scala> val nums = Seq(1,2,3)
nums: Seq[Int] = List(1, 2, 3)
scala> val letters = Seq('a', 'b', 'c')
letters: Seq[Char] = List(a, b, c)
scala> val res = for {
| n <- nums
| c <- letters
| } yield (n, c)
res: Seq(Int,Char) = List((1,a),(1,b),(1,c),(2,a),(2,b),(2,c),(3,a),(3,b),(3,c))
希望这能有所帮助!!
https://stackoverflow.com/questions/1052476
复制相似问题