Метод Async.SwitchToContext (F#)
Создает асинхронное вычисление, которое запускает свое продолжение, используя метод Post в предоставленном объекте контекста синхронизации.
Пространство имен/путь к модулю: Microsoft.FSharp.Control
Сборка: FSharp.Core (в FSharp.Core.dll)
// Signature:
static member SwitchToContext : SynchronizationContext -> Async<unit>
// Usage:
Async.SwitchToContext (syncContext)
Параметры
syncContext
Тип: SynchronizationContextКонтекст синхронизации для приема переданного вычисления.
Возвращаемое значение
Асинхронное вычисление, для выполнения которого используется контекст syncContext.
Заметки
Если syncContext имеет значение NULL, асинхронное вычисление эквивалентно Async.SwitchToThreadPool.
Пример
В следующем примере кода показано использование Async.SwitchToContext для переключения на поток пользовательского интерфейса для обновления пользовательского интерфейса. В этом случае индикатор выполнения, указывающий состояние выполнения вычисления, обновляется.
open System.Windows.Forms
let form = new Form(Text = "Test Form", Width = 400, Height = 400)
let syncContext = System.Threading.SynchronizationContext.Current
let button1 = new Button(Text = "Start")
let label1 = new Label(Text = "", Height = 200, Width = 200,
Top = button1.Height + 10)
form.Controls.AddRange([| button1; label1 |] )
type invokeFunction = delegate of unit -> unit
let async1(syncContext, form : System.Windows.Forms.Form) =
async {
let label1 = form.Controls.[1]
// Do something.
do! Async.Sleep(1000)
// Switch to the UI thread and update the UI.
do! Async.SwitchToContext(syncContext)
let threadNumber = System.Threading.Thread.CurrentThread.ManagedThreadId
label1.Text <- label1.Text + sprintf "On the UI Thread [%d]\n" threadNumber
// Switch back to the thread pool.
do! Async.SwitchToThreadPool()
// Do something.
do! Async.Sleep(1000)
let threadNumber = System.Threading.Thread.CurrentThread.ManagedThreadId
// When on a thread pool thread, use Control.Invoke to update UI.
label1.Invoke(new invokeFunction(fun () ->
label1.Text <- label1.Text +
sprintf "Switched to thread pool [%d]\n" threadNumber)) |> ignore
}
let buttonClick(sender:obj, args) =
let button = sender :?> Button
Async.Start(async1(syncContext, button.Parent :?> Form))
let threadNumber = System.Threading.Thread.CurrentThread.ManagedThreadId
label1.Text <- sprintf "Started asynchronous workflow [%d]\n" threadNumber
()
button1.Click.AddHandler(fun sender args -> buttonClick(sender, args))
Application.Run(form)
Платформы
Windows 7, Windows Vista с пакетом обновления 2 (SP2), Windows XP с пакетом обновления 3 (SP3), Windows XP x64 с пакетом обновления 2 (SP2), Windows Server 2008 R2, Windows Server 2008 с пакетом обновления 2 (SP2), Windows Server 2003 с пакетом обновления 2 (SP2)
Сведения о версии
Среда выполнения F#
Поддерживается в версиях 2.0, 4.0
Silverlight
Поддерживается в версии 3
См. также
Ссылки
Пространство имен Microsoft.FSharp.Control (F#)
Журнал изменений
Дата |
Журнал |
Причина |
---|---|---|
Июль 2010 |
Добавлен пример кода. |
Улучшение информации. |