Async.StartChild <'T> Metoda (F#)
Uruchamia obliczeń podrzędnych w ramach asynchronicznego przepływu pracy.Pozwala to wielu asynchronicznego obliczenia wykonywane jednocześnie.
Ścieżka obszaru nazw/modułu: Microsoft.FSharp.Control
Zgromadzenie: FSharp.Core (w FSharp.Core.dll)
// Signature:
static member StartChild : Async<'T> * ?int -> Async<Async<'T>>
// Usage:
Async.StartChild (computation)
Async.StartChild (computation, millisecondsTimeout = millisecondsTimeout)
Parametry
computation
Typ: asynchroniczne<'T>Dziecko obliczeń.
millisecondsTimeout
Typ: intWartość limitu czasu w milisekundach.Jeśli jeden nie podano wartość domyślna jest -1, która odpowiada Infinite.
Wartość zwracana
Nowe obliczenie czeka wprowadzania obliczeń, aby zakończyć.
Uwagi
Ta metoda normalnie powinien służyć jako natychmiastowego prawo-nadwozia1-boku let! wiązania w F# przepływu asynchronicznych, to znaczy:
async {
...
let! completor1 = childComputation1
|> Async.StartChild
let! completor2 = childComputation2
|> Async.StartChild
...
let! result1 = completor1
let! result2 = completor2
... }
Użyty w ten sposób używać każdego z StartChild uruchamia wystąpienie childComputation i zwraca completor obiekt reprezentujący obliczeń czekać na zakończenie operacji.Podczas wykonywania completor oczekuje na zakończenie childComputation.
Przykład
Poniższy przykład kodu ilustruje użycie 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)
Przykładowe dane wyjściowe
Ponieważ jednoczesne wykonywanie zadań jest z przeplotem danych wyjściowych.
Platformy
Windows 8, Windows 7, Windows Server 2012 Windows Server 2008 R2
Informacje o wersji
F# Core wersji biblioteki
Obsługiwane: 2.0, 4.0, przenośne