Функция Seq.fold<'T,'State> (F#)
Применяет функцию к каждому элементу коллекции, передавая накапливаемое значение аргумента по потоку в процессе вычисления.Если входная функция — f, а элементы — i0...iN, эта функция вычисляет f (... (f s i0)...) iN.
Пространство имен/путь к модулю: Microsoft.FSharp.Collections.Seq
Сборка: FSharp.Core (в FSharp.Core.dll)
// Signature:
Seq.fold : ('State -> 'T -> 'State) -> 'State -> seq<'T> -> 'State
// Usage:
Seq.fold folder state source
Параметры
folder
Тип: 'State -> 'T -> 'StateФункция, обновляющая состояние посредством каждого элемента последовательности.
state
Тип: 'StateНачальное состояние.
source
Тип: seq<'T>Входная последовательность.
Исключения
Исключение |
Атрибут Condition |
---|---|
Создается при указании в качестве входной последовательности значения NULL. |
Возвращаемое значение
Конечный результат вычислений.
Заметки
В скомпилированных сборках имя этой функции — Fold.При обращении к функции из языка, отличного от F#, или посредством отражения следует использовать это имя.
Пример
В следующем коде показано, как использовать Seq.fold для реализации функции, которая вычисляет сумму элементов последовательности.
let sumSeq sequence1 = Seq.fold (fun acc elem -> acc + elem) 0 sequence1
Seq.init 10 (fun index -> index * index)
|> sumSeq
|> printfn "The sum of the elements is %d."
Output
Платформы
Windows 8, Windows 7, Windows Server 2012, Windows 2008 Server R2
Сведения о версии
Основной версии библиотеки F#
Поддерживается в: 2.0, 4.0, портативное