IInputChannel.WaitForMessage(TimeSpan) Método

Definição

Retorna um valor que indica se uma mensagem chegou dentro de um intervalo de tempo especificado.

public:
 bool WaitForMessage(TimeSpan timeout);
public bool WaitForMessage(TimeSpan timeout);
abstract member WaitForMessage : TimeSpan -> bool
Public Function WaitForMessage (timeout As TimeSpan) As Boolean

Parâmetros

timeout
TimeSpan

Especifica TimeSpan o intervalo máximo de tempo para aguardar a chegada de uma mensagem antes do tempo limite.

Retornos

true se uma mensagem tiver chegado antes de timeout ter sido excedida; caso contrário false.

Exceções

O especificado timeout é excedido antes da conclusão da operação.

O tempo limite especificado é menor que zero.

Exemplos

O código a seguir ilustra como implementar este método:

public bool WaitForMessage(TimeSpan timeout)
{
    return this.InnerChannel.WaitForMessage(timeout);
}

Comentários

A chamada WaitForMessage(TimeSpan) não resulta em uma mensagem sendo recebida ou processada de outra maneira.

O WaitForMessage(TimeSpan) método existe principalmente para cenários transacionados em que o usuário deseja receber a mensagem usando uma transação. Ao usar normalmente Receive para isso, o usuário deve criar a transação e, em seguida, chamar Receive e esperar que a mensagem chegue antes do tempo limite da transação, o que pode não ser possível.

Em vez disso, o usuário pode ligar WaitForMessage(TimeSpan) com o tempo limite desejado (mesmo infinito) e, quando uma mensagem chegar, poderá abrir a transação, ligar Receive e ter certeza de que pode receber a mensagem de volta antes que a transação expire.

Esse método é síncrono, portanto, bloqueia o thread atual até que uma mensagem esteja disponível ou o tempo limite ocorra. Use WaitForMessage(TimeSpan) quando for aceitável que o thread atual seja bloqueado enquanto aguarda a chegada de uma mensagem na fila. O thread é bloqueado até o especificado timeout. Se você precisar que o processamento do aplicativo continue sem esperar, use o método assíncrono BeginWaitForMessage(TimeSpan, AsyncCallback, Object) .

Notas aos Implementadores

A operação retornará false se o especificado timeout for excedido, não uma exceção de tempo limite.

Aplica-se a