Compartilhar via


MailboxProcessor.PostAndAsyncReply < "Msg," resposta > Método (F#)

Remete uma mensagem para um agente e aguardar uma resposta no canal, de forma assíncrona.

Caminho do namespace/módulo: Microsoft.FSharp.Control

Assembly: FSharp.Core (em FSharp.Core.dll)

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

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

Parâmetros

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

    A função incorporar a AsyncReplyChannel da mensagem a ser enviada.

  • timeout
    Tipo: int

    Um parâmetro opcional de tempo limite (em milissegundos) aguardar uma mensagem de resposta. O padrão é -1, o que corresponde a Infinite().

Valor de retorno

Uma computação assíncrona (Async objeto) que irá aguardar a resposta do agente.

Comentários

A mensagem é gerada pela aplicação buildMessage para um novo canal de resposta sejam incorporados a mensagem. O agente de recebimento deve processar esta mensagem e chamar o método de resposta neste canal de resposta de exatamente uma vez.

Exemplo

O exemplo de código a seguir mostra um agente de processador de caixa de correio que usa PostAndAsyncReply. O valor de retorno de PostAndAsyncReply é um fluxo de trabalho assíncrono, que neste exemplo é iniciado usando Async.StartWithContinuations, para configurar o código que manipula a resposta.

open System

type Message = string * AsyncReplyChannel<string>

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

let agent = MailboxProcessor<Message>.Start(fun inbox ->
    let rec loop n =
        async {            
                let! (message, replyChannel) = inbox.Receive();
                // Delay so that the responses come in a different order.
                do! Async.Sleep( 5000 - 1000 * n);
                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."

let isCompleted = false
while (not isCompleted) do
    printf "> "
    let input = Console.ReadLine()
    let messageAsync = agent.PostAndAsyncReply(fun replyChannel -> input, replyChannel)

    // Set up a continuation function (the first argument below) that prints the reply.
    // The second argument is the exception continuation (not used).
    // The third argument is the cancellation continuation (not used).
    Async.StartWithContinuations(messageAsync, 
         (fun reply -> printfn "%s" reply),
         (fun _ -> ()),
         (fun _ -> ()))

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

A seguir é uma sessão de exemplo. A saída pode ser entrelaçada, que mostra que a função de processamento de mensagem está sendo executado em vários segmentos.

                      

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

Control.MailboxProcessor <'Msg > Classe (F#)

Microsoft.FSharp.Control Namespace (F#)

Histórico de alterações

Date

History

Motivo

Janeiro de 2011

Exemplo de código adicionado.

Aprimoramento de informações.