Async.StartImmediate (Método de F#)

Ejecuta un cálculo asincrónico y comienza inmediatamente en el subproceso actual del sistema operativo.

Espacio de nombres/Ruta de acceso del módulo: Microsoft.FSharp.Control

Ensamblado: FSharp.Core (en FSharp.Core.dll)

// Signature:
static member StartImmediate : Async<unit> * CancellationToken option -> unit

// Usage:
Async.StartImmediate (computation)
Async.StartImmediate (computation, cancellationToken = cancellationToken)

Parámetros

  • computation
    Tipo: Async<unit>

    Cálculo asincrónico que se va a ejecutar.

  • cancellationToken
    Tipo: CancellationToken

    Token de cancelación opcional que se va a asociar al cálculo. Si no se proporciona este parámetro, se usará el valor predeterminado.

Comentarios

Si no se proporciona ningún token de cancelación, se usará el token de cancelación predeterminado.

Ejemplo

En el ejemplo de código siguiente se muestra cómo usar Async.StartImmediate para iniciar un cálculo asincrónico en el subproceso actual. A menudo, una operación asincrónica debe actualizar la interfaz de usuario; esta operación debe realizarse siempre en el subproceso de la interfaz de usuario. Cuando la operación asincrónica debe comenzar por actualizar la interfaz de usuario, Async.StartImmediate es una opción mejor que Async.Start, que inicia la operación asincrónica en un subproceso de grupo de subprocesos.


open System.Windows.Forms

let bufferData = Array.zeroCreate<byte> 100000000

let async1 (button : Button) =
     async {
       button.Text <- "Busy"
       button.Enabled <- false
       let context = System.Threading.SynchronizationContext.Current
       do! Async.SwitchToThreadPool()
       use outputFile = System.IO.File.Create("longoutput.dat")
       do! outputFile.AsyncWrite(bufferData)
       do! Async.SwitchToContext(context)
       button.Text <- "Start"
       button.Enabled <- true
     }


let form = new Form(Text = "Test Form")
let button = new Button(Text = "Start")
form.Controls.Add(button)
button.Click.Add(fun args -> Async.StartImmediate(async1 button))
Application.Run(form)

Plataformas

Windows 7, Windows Vista SP2, Windows XP SP3, Windows XP x64 SP2, Windows Server 2008 R2, Windows Server 2008 SP2, Windows Server 2003 SP2

Información de versiones

Runtime de F#

Se admite en las versiones: 2.0, 4.0

Silverlight

Se admite en la versión: 3

Vea también

Referencia

Control.Async (Clase de F#)

Microsoft.FSharp.Control (Espacio de nombres de F#)

Historial de cambios

Fecha

Historial

Motivo

Agosto de 2010

Ejemplo de código mejorado.

Mejora de la información.