Método Async.StartImmediate (F#)
Executa uma computação assíncrona, iniciando imediatamente no thread do sistema operacional atual.
Caminho do namespace/módulo: Microsoft.FSharp.Control
Assembly: FSharp.Core (em 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<unidade>A computação assíncrona para executar.
cancellationToken
Tipo: CancellationTokenO token de cancelamento opcional para associar a computação. Se este parâmetro não for fornecido, será usado o padrão.
Comentários
Se nenhum token de cancelamento é fornecido o símbolo de cancelamento padrão é usado.
Exemplo
O exemplo de código a seguir mostra como usar Async.StartImmediate para iniciar uma computação assíncrona no thread atual. Geralmente, uma operação assíncrona precisa atualizar a interface do usuário, deve sempre ser feita no thread da interface do usuário. Quando a operação assíncrona precisa para começar a atualizar a interface do usuário, Async.StartImmediate é uma opção melhor do que Async.Start, que inicia a operação assíncrona em um thread do pool.
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
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 aperfeiçoada. |
Aprimoramento de informações. |