Функция 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 |
---|---|
Создается, если список пуст. |
Возвращаемое значение
Окончательное приведенное значение.
Заметки
В скомпилированных сборках имя этой функции — 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, портативное