Função Array.tryFind<'T> (F#)
Retorna o primeiro elemento para que a função retorna determinada true. None de retorno se nenhum tal elemento existe.
Namespace/Module Path: Microsoft.FSharp.Collections.Array
Assembly: FSharp.Core (em FSharp.Core.dll)
// Signature:
Array.tryFind : ('T -> bool) -> 'T [] -> 'T option
// Usage:
Array.tryFind predicate array
Parâmetros
predicate
Tipo: 'T ->boolA função para testar os elementos de entrada.
array
Tipo: 'T[]A matriz de entrada.
Valor de retorno
o primeiro elemento que satisfaz o predicado, ou None.
Comentários
Essa função é chamada TryFind em assemblies compilados. Se você está acessando a função de uma linguagem .NET a não ser F#, ou com a reflexão, use este nome.
Exemplo
O exemplo a seguir demonstra o uso de Array.tryFind tentar posicionar elementos da matriz que são aperfeiçoam cubos e quadrados perfeitos.
let delta = 1.0e-10
let isPerfectSquare (x:int) =
let y = sqrt (float x)
abs(y - round y) < delta
let isPerfectCube (x:int) =
let y = System.Math.Pow(float x, 1.0/3.0)
abs(y - round y) < delta
let lookForCubeAndSquare array1 =
let result = Array.tryFind (fun elem -> isPerfectSquare elem && isPerfectCube elem) array1
match result with
| Some x -> printfn "Found an element: %d" x
| None -> printfn "Failed to find a matching element."
lookForCubeAndSquare [| 1 .. 10 |]
lookForCubeAndSquare [| 100 .. 1000 |]
lookForCubeAndSquare [| 2 .. 50 |]
Plataformas
O windows 8, Windows 7, Windows Server 2012, Windows Server 2008 R2
Informações de Versão
Versões da biblioteca principal de F#
Suportado em: 2,0, 4,0, portáteis