MailboxProcessor.PostAndAsyncReply < "Msg," resposta > Método (F#)
Enviar uma mensagem a um agente e esperam uma resposta no canal, de forma assíncrona.
Namespace/Module Path: 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> -> 'MsgA função para inserir o AsyncReplyChannel na mensagem a ser enviada.
timeout
Tipo: intUm parâmetro de tempo limite em milissegundos (opcional) para esperar uma mensagem de resposta.O padrão é -1 que corresponde a Infinite.
Valor de retorno
Uma asychronous (computação objeto deAsync ) que aguardar a resposta do.
Comentários
A mensagem é gerada aplicando buildMessage a um novo canal de resposta a ser inserido na mensagem.O agente de recepção deve processar esta mensagem e chamar o método de resposta no canal de resposta precisamente uma vez.
Exemplo
O exemplo de código a seguir mostra um agente do processador de caixa postal que usa PostAndAsyncReply.O valor de retorno de PostAndAsyncReply é um fluxo de trabalho assíncrona, que em este 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 está uma sessão exemplo.A saída podem ser intercaladas, que mostra a que a função de processamento de mensagens estão executando em vários segmentos.
Plataformas
O windows 8, Windows 7, Windows Server 2012, Windows Server 2008 R2
Informações de Versão
Versões da biblioteca principal de F#
Suportado em: 2,0, 4,0, portáteis