Async.StartChild <'T>. Método (F#)
Inicia uma computação filho dentro de um fluxo de trabalho assíncrono. Isso permite que vários computações assíncronas a ser executadas simultaneamente.
Caminho do namespace/módulo: Microsoft.FSharp.Control
Assembly: FSharp.Core (em FSharp.Core.dll)
// Signature:
static member StartChild : Async<'T> * ?int -> Async<Async<'T>>
// Usage:
Async.StartChild (computation)
Async.StartChild (computation, millisecondsTimeout = millisecondsTimeout)
Parâmetros
computation
Tipo: Async<'T>A computação filho.
millisecondsTimeout
Tipo: intO valor de tempo limite em milissegundos. Se não for fornecido, em seguida, o valor padrão é -1, que corresponde a Infinite.
Valor de retorno
Uma nova computação que aguarda a computação de entrada concluir.
Comentários
Este método normalmente deve ser usado como o imediato direita-hand-lado de um let! de vinculação em um F# de fluxo de trabalho assíncrono, isto é:
async {
...
let! completor1 = childComputation1
|> Async.StartChild
let! completor2 = childComputation2
|> Async.StartChild
...
let! result1 = completor1
let! result2 = completor2
... }
Quando usado dessa maneira, cada um use de StartChild inicia uma instância do childComputation e retorna um completor objeto representando um cálculo de aguardar a conclusão da operação. Quando executado, o completor aguarda a conclusão de childComputation.
Exemplo
O exemplo de código a seguir ilustra o uso do Async.StartChild.
open System.Windows.Forms
let bufferData = Array.zeroCreate<byte> 100000000
let asyncChild filename =
async {
printfn "Child job start: %s" filename
use outputFile = System.IO.File.Create(filename)
do! outputFile.AsyncWrite(bufferData)
printfn "Child job end: %s " filename
}
let asyncParent =
async {
printfn "Parent job start."
let! childAsync1 = Async.StartChild(asyncChild "longoutput1.dat")
let! childAsync2 = Async.StartChild(asyncChild "longoutput2.dat")
let! result1 = childAsync1
let! result2 = childAsync2
printfn "Parent job end."
}
let form = new Form(Text = "Test Form")
let button = new Button(Text = "Start")
form.Controls.Add(button)
button.Click.Add(fun args -> Async.Start(asyncParent)
printfn "Completed execution." )
Application.Run(form)
Saída de exemplo
A saída é intercalada porque os trabalhos são executados simultaneamente.
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 |
---|---|---|
Julho de 2010 |
Exemplo de código adicionado. |
Aprimoramento de informações. |