在 F# 中,使用 Seq 模块与 List 相同,而且,我们已经知道,如何在 C# 中使用 LINQ 扩展方法。而在使用列表和序列方面,有一个显著区别:序列是延迟的。直到从返回序列中取出元素时,处理代码才执行,尽管那样,它所做的工作,也只是为了返回结果所需要的。现在,我们用简单的代码段来演示一下:
var nums1 = nums.Where(n => n%3 == 0) .Select(n => n * n) |
let nums1 = nums |> Seq.filter (fun n -> n%3=0) |> Seq.map (fun n -> n * n) |
当我们运行这段代码时,它不会处理任何元素;它只创建一个表示序列对象,可以用于访问元素;这还说明:nums 值可以是无穷数字序列。如果我们只访问序列的前 10 个元素,代码能够正常运行,因为筛选和映射都是延迟处理数据的。
使用高阶处理函数,经过我们在第六章深入讨论之后,你可能已经熟悉,在整本书中,我们提供了很多例子。在本章,我们将转而讨论表达可选工作流的方法。
时间: 2024-11-08 15:49:14