Seq.fold<'T,'State> (Función de F#)
Aplica una función a cada elemento de la colección y subprocesa un argumento acumulador durante el cálculo.Si la función de entrada es f y los elementos son i0...iN, esta función calcula f (... (f s i0)...) iN.
Espacio de nombres/Ruta de acceso del módulo: Microsoft.FSharp.Collections.Seq
Ensamblado: FSharp.Core (en FSharp.Core.dll)
// Signature:
Seq.fold : ('State -> 'T -> 'State) -> 'State -> seq<'T> -> 'State
// Usage:
Seq.fold folder state source
Parámetros
folder
Tipo: 'State -> 'T -> 'StateFunción que actualiza el estado de cada elemento de la secuencia.
state
Tipo: 'StateEstado inicial.
source
Tipo: seq<'T>Secuencia de entrada.
Excepciones
Excepción |
Condition |
---|---|
Se produce cuando la secuencia de entrada es NULL. |
Valor devuelto
Resultado final del cálculo.
Comentarios
Esta función se denomina Fold en los ensamblados compilados.Si obtiene acceso a la función desde un lenguaje distinto de F# o mediante reflexión, use este nombre.
Ejemplo
En el código siguiente se muestra cómo usar Seq.fold para implementar una función que calcula la suma de los elementos de una secuencia.
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
Plataformas
Windows 8, Windows 7, Windows Server 2012, Windows Server 2008 R2
Información de versiones
Versiones de la biblioteca básica de F#
Se admite en: 2.0, 4.0, portables