Метод MailboxProcessor.PostAndAsyncReply<'Msg,'Reply> (F#)
Отправляет агенту сообщение и ожидает ответа по каналу асинхронным образом.
Пространство имен/путь к модулю: Microsoft.FSharp.Control
Сборка: FSharp.Core (в FSharp.Core.dll)
// Signature:
member this.PostAndAsyncReply : (AsyncReplyChannel<'Reply> -> 'Msg) * ?int -> Async<'Reply>
// Usage:
mailboxProcessor.PostAndAsyncReply (buildMessage)
mailboxProcessor.PostAndAsyncReply (buildMessage, timeout = timeout)
Параметры
buildMessage
Тип: AsyncReplyChannel<'Reply> -> 'MsgФункция, используемая для включения AsyncReplyChannel в отправляемое сообщение.
timeout
Тип: intНеобязательный параметр времени ожидания ответного сообщения (в миллисекундах). По умолчанию установлено значение -1, которое соответствует значению Infinite().
Возвращаемое значение
Асинхронное вычисление (объект Async), ожидающее ответа агента.
Заметки
Сообщение создается путем применения функции buildMessage к новому каналу ответа, включаемому в сообщение. Агент-получатель должен обработать данное сообщение и вызвать метод Reply для этого канала ответа ровно один раз.
Пример
В следующем примере кода показан агент почтового процессора, использующий PostAndAsyncReply. Возвращаемое значение PostAndAsyncReply — асинхронный рабочий процесс, который в этом примере запускается с помощью Async.StartWithContinuations, чтобы настроить код, который обрабатывает ответ.
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
Ниже приведен пример сеанса. Результаты могут чередоваться, что говорит о том, что функция обработки сообщений выполняется в нескольких потоках.
Платформы
Windows 7, Windows Vista с пакетом обновления 2 (SP2), Windows XP с пакетом обновления 3 (SP3), Windows XP x64 с пакетом обновления 2 (SP2), Windows Server 2008 R2, Windows Server 2008 с пакетом обновления 2 (SP2), Windows Server 2003 с пакетом обновления 2 (SP2)
Сведения о версии
Среда выполнения F#
Поддерживается в версиях 2.0, 4.0
Silverlight
Поддерживается в версии 3
См. также
Ссылки
Класс Control.MailboxProcessor<'Msg> (F#)
Пространство имен Microsoft.FSharp.Control (F#)
Журнал изменений
Дата |
Журнал |
Причина |
---|---|---|
Январь 2011 |
Добавлен пример кода. |
Улучшение информации. |