Funzione List.foldBack<'T,'State> (F#)
Applica una funzione a ogni elemento della raccolta, eseguendo il threading di un argomento di accumulatore attraverso il calcolo. Se la funzione di input è f e gli elementi sono i0...iN, tale funzione calcola f i0 (...(f iN s)).
Percorso di spazio dei nomi/modulo: Microsoft.FSharp.Collections.List
Assembly: FSharp.Core (in FSharp.Core.dll)
// Signature:
List.foldBack : ('T -> 'State -> 'State) -> 'T list -> 'State -> 'State
// Usage:
List.foldBack folder list state
Parametri
folder
Tipo: 'T -> 'State -> 'StateFunzione da utilizzare per aggiornare lo stato in base agli elementi di input.
list
Tipo: 'T listElenco di input.
state
Tipo: 'StateStato iniziale.
Valore restituito
Valore dello stato finale.
Note
Questa funzione è denominata FoldBack negli assembly compilati. Utilizzare questo nome se si accede alla funzione da un linguaggio diverso da F# o tramite reflection.
Esempio
Nell'esempio di codice seguente viene illustrato l'utilizzo di List.foldBack.
let sumListBack list = List.foldBack (fun acc elem -> acc + elem) list 0
printfn "%d" (sumListBack [1; 2; 3])
// For a calculation in which the order of traversal is important, fold and foldBack have different
// results. For example, replacing foldBack with fold in the copyList function
// produces a function that reverses the list, rather than copying it.
let copyList list = List.foldBack (fun elem acc -> elem::acc) list []
printfn "%A" (copyList [1 .. 10])
Output
Piattaforme
Windows 8, Windows 7, Windows Server 2012, Windows Server 2008 R2
Informazioni sulla versione
Versioni della libreria di base F#
Supportato in: 2,0, 4,0, portabile