MailboxProcessor.PostAndReply<'Msg,'Reply> メソッド (F#)

更新 : 2011 年 1 月

エージェントにメッセージをポストし、チャネルの応答を同期的に待機します。

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

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

// Signature:
member this.PostAndReply : (AsyncReplyChannel<'Reply> -> 'Msg) * ?int -> 'Reply

// Usage:
mailboxProcessor.PostAndReply (buildMessage)
mailboxProcessor.PostAndReply (buildMessage, timeout = timeout)

パラメーター

  • buildMessage
    型: AsyncReplyChannel<'Reply> -> 'Msg

    送信されるメッセージに AsyncReplyChannel を組み込む関数。

  • timeout
    型: int

    応答メッセージを待機するオプションのタイムアウト パラメーター (ミリ秒単位)。 既定値は Infinite() に対応する -1 です。

戻り値

エージェントからの応答。

解説

メッセージは、メッセージに結合される新しい応答チャネルに buildMessage を適用することで生成されます。 受信するエージェントは、このメッセージを処理し、この応答チャネル上の Reply メソッドを正確に 1 回呼び出す必要があります。

使用例

メールボックス プロセッサ エージェントを起動する方法のコード例を次に示します。 この例では、コンソールからの各入力行がメッセージ キューにポストされます。 プログラムは各メッセージを読み取り、応答チャネルを使用して応答します。 特別なメッセージ "Stop" を受信すると、Stop 応答を送信し、プログラムが終了します。

open System

type Message = string * AsyncReplyChannel<string>

let formatString = "Message number {0} was received. Message contents: {1}"

let printThreadId note =

    // Append the thread ID.
    printfn "%d : %s" System.Threading.Thread.CurrentThread.ManagedThreadId note


let agent = MailboxProcessor<Message>.Start(fun inbox ->
    let rec loop n =
        async {
                let! (message, replyChannel) = inbox.Receive();
                printThreadId "MailboxProcessor"
                if (message = "Stop") then
                    replyChannel.Reply("Stopping.")
                else
                    replyChannel.Reply(String.Format(formatString, n, message))
                do! loop (n + 1)
        }
    loop 0)

printfn "Mailbox Processor Test"
printfn "Type some text and press Enter to submit a message."
printfn "Type 'Stop' to close the program."

let rec loop() =
    printf "> "
    let input = Console.ReadLine()
    printThreadId("Console loop")
    let reply = agent.PostAndReply(fun replyChannel -> input, replyChannel)
    if (reply <> "Stopping.") then
        printfn "Reply: %s" reply
        loop()
    else
        ()
loop()

printfn "Press Enter to continue."
Console.ReadLine() |> ignore

セッション例を次に示します。

                    

プラットフォーム

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.MailboxProcessor<'Msg> クラス (F#)

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

履歴の変更

日付

履歴

理由

2011 年 1 月

コード例を追加。

情報の拡充