Async.SwitchToContext 方法 (F#)
更新:2010 年 7 月
建立一個非同步計算執行其註解的接續使用 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切換至 UI 執行緒更新 UI。 在這項目,會更新案例表示的計算完成狀態的進度列。
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 SP2、Windows XP SP3、Windows XP x64 SP2、Windows Server 2008 R2、Windows Server 2008 SP2、Windows Server 2003 SP2
版本資訊
F# 執行階段
支援版本:2.0、4.0
Silverlight
支援版本:3
請參閱
參考
Microsoft.FSharp.Control 命名空間 (F#)
變更記錄
日期 |
History |
原因 |
---|---|---|
2010 年 7 月 |
加入程式碼範例。 |
資訊加強。 |