Metodo Async.StartAsTask<'T> (F#)
Esegue un calcolo asincrono nel pool di thread.Restituisce un oggetto Task che sarà completato nello stato corrispondente al termine del calcolo (produce il risultato, genera un'eccezione o viene annullato). Se non viene fornito alcun token di annullamento, viene utilizzato il token di annullamento predefinito.
Percorso di spazio dei nomi/modulo: Microsoft.FSharp.Control
Assembly: FSharp.Core (in FSharp.Core.dll)
// Signature:
static member StartAsTask : Async<'T> * ?TaskCreationOptions * ?CancellationToken -> Task<'T>
// Usage:
Async.StartAsTask (computation)
Async.StartAsTask (computation, taskCreationOptions = taskCreationOptions, cancellationToken = cancellationToken)
Parametri
computation
Tipo: Async<'T>Calcolo da eseguire.
taskCreationOptions
Tipo: TaskCreationOptionsOpzioni di creazione di attività facoltative.
cancellationToken
Tipo: CancellationTokenToken di annullamento opzionale.
Valore restituito
Oggetto Task<TResult> che rappresenta il calcolo fornito.
Esempio
Nell'esempio di codice seguente viene illustrato l'utilizzo di Async.StartAsTask.
open System.Windows.Forms
let bufferData = Array.zeroCreate<byte> 100000000
let async1 =
async {
use outputFile = System.IO.File.Create("longoutput.dat")
do! outputFile.AsyncWrite(bufferData)
}
let form = new Form(Text = "Test Form")
let button = new Button(Text = "Start")
form.Controls.Add(button)
button.Click.Add(fun args -> let task = Async.StartAsTask(async1)
printfn "Do some other work..."
task.Wait()
printfn "done")
Application.Run(form)
Piattaforme
Windows 8, Windows 7, Windows Server 2012, Windows Server 2008 R2
Informazioni sulla versione
Versioni della libreria di base F#
Supportato in: 4,0, portabile