Async.StartImmediate メソッド (F#)

更新 : 2010 年 8 月

非同期計算を実行し、現在のオペレーティング システムのスレッドですぐに開始します。

名前空間/モジュール パス: Microsoft.FSharp.Control

アセンブリ: FSharp.Core (FSharp.Core.dll 内)

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

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

パラメーター

  • computation
    型: ee370518(v=vs.100).md<Asyncee370213(v=vs.100).md>unit

    実行する非同期計算。

  • cancellationToken
    型: CancellationToken

    計算に関連付ける省略可能なキャンセル トークン。 このパラメーターを指定しない場合は、既定値が使用されます。

解説

キャンセル トークンが指定されていない場合は、既定のキャンセル トークンが使用されます。

使用例

Async.StartImmediate を使用して現在のスレッドで非同期計算を開始する方法を次のコード例に示します。 多くの場合、非同期操作では UI を更新する必要があり、この更新は常に UI スレッドで実行する必要があります。 非同期操作で最初に UI を更新する必要がある場合には、スレッド プールのスレッドで非同期操作を開始する Async.Start よりも、Async.StartImmediate の方が適しています。


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)

プラットフォーム

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

参照

その他の技術情報

Control.Async クラス (F#)

Microsoft.FSharp.Control 名前空間 (F#)

履歴の変更

日付

履歴

理由

2010 年 8 月

コード例が改善されました。

情報の拡充