Condividi tramite


Funzione Map.findKey<'Key,'T> (F#)

Valuta la funzione su ogni mapping nella raccolta e restituisce la chiave per il primo mapping in cui la funzione restituisce true.Se tale elemento non esiste, viene generata questa funzione KeyNotFoundException.

Percorso spazio dei nomi/modulo: Microsoft.FSharp.Collections.Map

Assembly: FSharp.Core (in FSharp.Core.dll)

// Signature:
Map.findKey : ('Key -> 'T -> bool) -> Map<'Key,'T> -> 'Key (requires comparison)

// Usage:
Map.findKey predicate table

Parametri

  • predicate
    Tipo: 'Key -> 'T ->bool

    Funzione da utilizzare per eseguire il test degli elementi di input.

  • table
    Tipo: Map<'Key,'T>

    Mappa di input.

Eccezioni

Eccezione

Condizione

KeyNotFoundException

Generata se la chiave non è presente nella mappa.

Valore restituito

Prima chiave per la quale il predicato restituisce true.

Note

Questa funzione è denominata FindKey negli assembly compilati.Utilizzare questo nome se si accede alla funzione da un linguaggio diverso da F# o tramite reflection.

Esempio

Nell'esempio riportato di seguito viene illustrato l'utilizzo di Map.findKey.

let findKeyFromValue findValue map =
    printfn "With value %A, found key %A." findValue (Map.findKey (fun key value -> value = findValue) map)
let map1 = Map.ofList [ (1, "one"); (2, "two"); (3, "three") ]
let map2 = Map.ofList [ for i in 1 .. 10 -> (i, i*i) ]
try
    findKeyFromValue "one" map1
    findKeyFromValue "two" map1
    findKeyFromValue 9 map2
    findKeyFromValue 25 map2
    // The key is not in the map, so the following line throws an exception.
    findKeyFromValue 0 map2
with
     :? System.Collections.Generic.KeyNotFoundException as e -> printfn "%s" e.Message

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

Vedere anche

Riferimenti

Modulo Collections.Map (F#)

Spazio dei nomi Microsoft.FSharp.Collections (F#)