Método Async.AwaitIAsyncResult (F#)
Cria uma computação assíncrona, aguardará o IAsyncResult.
Caminho do namespace/módulo: Microsoft.FSharp.Control
Assembly: FSharp.Core (em FSharp.Core.dll)
// Signature:
static member AwaitIAsyncResult : IAsyncResult * ?int -> Async<bool>
// Usage:
Async.AwaitIAsyncResult (iar)
Async.AwaitIAsyncResult (iar, millisecondsTimeout = millisecondsTimeout)
Parâmetros
iar
Tipo: IAsyncResultPara esperar por IAsyncResult.
millisecondsTimeout
Tipo: intO valor de tempo limite em milissegundos. Se um não for fornecido, em seguida, o valor padrão de -1, correspondente a Infinite.
Valor de retorno
Uma computação assíncrona que aguarda a determinado IAsyncResult.
Comentários
A computação retorna true se a alça indicado um resultado dentro do tempo limite determinado.
Exemplo
O exemplo de código a seguir ilustra como usar Async.AwaitIAsyncResult para configurar e executar uma computação é disparada quando a versão anterior.Operação assíncrona do NET Framework que produz uma IAsyncResult terminar. Neste caso, a chamada para AwaitIAsyncResult faz com que a operação de esperar por uma operação de gravação de arquivo ser concluída antes de abrir o arquivo para leitura.
open System.IO
let streamWriter1 = File.CreateText("test1.txt")
let count = 10000000
let buffer = Array.init count (fun index -> byte (index % 256))
printfn "Writing to file test1.txt."
let asyncResult = streamWriter1.BaseStream.BeginWrite(buffer, 0, count, null, null)
// Read a file, but use AwaitIAsyncResult to wait for the write operation
// to be completed before reading.
let readFile filename asyncResult count =
async {
let! returnValue = Async.AwaitIAsyncResult(asyncResult)
printfn "Reading from file test1.txt."
// Close the file.
streamWriter1.Close()
// Now open the same file for reading.
let streamReader1 = File.OpenText(filename)
let! newBuffer = streamReader1.BaseStream.AsyncRead(count)
return newBuffer
}
let bufferResult = readFile "test1.txt" asyncResult count
|> Async.RunSynchronously
Plataformas
O Windows 7, SP2 do Windows Vista, Windows XP SP3, Windows XP Professional x64 SP2, Windows Server 2008 R2, Windows Server 2008 SP2, Windows Server 2003 SP2
Informações sobre versão
O tempo de execução F#
Compatível com: 2.0, 4.0
Silverlight
Compatível com: 3
Consulte também
Referência
Microsoft.FSharp.Control Namespace (F#)
Histórico de alterações
Date |
History |
Motivo |
---|---|---|
Agosto de 2010 |
Exemplo de código adicionado. |
Aprimoramento de informações. |