Поделиться через


Функция 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

ArgumentNullException

Создается при указании в качестве входной последовательности значения 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, портативное

См. также

Ссылки

Модуль Collections.Seq (F#)

Пространство имен Microsoft.FSharp.Collections (F#)