Compartir a través de


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 -> 'State

    Función que actualiza el estado de cada elemento de la secuencia.

  • state
    Tipo: 'State

    Estado inicial.

  • source
    Tipo: seq<'T>

    Secuencia de entrada.

Excepciones

Excepción

Condition

ArgumentNullException

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

Vea también

Referencia

Collections.Seq (Módulo de F#)

Microsoft.FSharp.Collections (Espacio de nombres de F#)