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


Функция List.reduce<'T> (F#)

Применяет функцию к каждому элементу коллекции, передавая накапливаемое значение аргумента по потоку в процессе вычисления.Работа этой функции начинается с ее применения к двум первым элементам списка.Затем этот результат передается в функцию вместе с третьим элементом и т. д.Наконец, она возвращает окончательный результат.Если входная функция — f, а элементы — i0...iN, вычисляется f (... (f i0 i1) i2 ...) iN.

Пространство имен/путь к модулю: Microsoft.FSharp.Collections.List

Сборка: FSharp.Core (в FSharp.Core.dll)

// Signature:
List.reduce : ('T -> 'T -> 'T) -> 'T list -> 'T

// Usage:
List.reduce reduction list

Параметры

  • reduction
    Тип: 'T -> 'T -> 'T

    Функция для приведения двух элементов списка к одному элементу.

  • list
    Тип: 'T list

    Входной список.

Исключения

Исключение

Атрибут Condition

ArgumentException

Создается, если список пуст.

Возвращаемое значение

Окончательное приведенное значение.

Заметки

В скомпилированных сборках имя этой функции — Reduce.При обращении к функции из языка, отличного от F#, или посредством отражения следует использовать это имя.

Пример

В следующем примере кода демонстрируется использование функции List.reduce.

let sumAList list =
    try
        List.reduce (fun acc elem -> acc + elem) list
    with
       | :? System.ArgumentException as exc -> 0

let resultSum = sumAList [2; 4; 10]
printfn "%d " resultSum

Output

  

Платформы

Windows 8, Windows 7, Windows Server 2012, Windows 2008 Server R2

Сведения о версии

Основной версии библиотеки F#

Поддерживается в: 2.0, 4.0, портативное

См. также

Ссылки

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

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