BufferBlock<T>.ISourceBlock<T>.ReserveMessage Método
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Chamado por um ITargetBlock<TInput> vinculado para reservar um DataflowMessageHeader oferecido anteriormente por este ISourceBlock<TOutput>.
virtual bool System.Threading.Tasks.Dataflow.ISourceBlock<T>.ReserveMessage(System::Threading::Tasks::Dataflow::DataflowMessageHeader messageHeader, System::Threading::Tasks::Dataflow::ITargetBlock<T> ^ target) = System::Threading::Tasks::Dataflow::ISourceBlock<T>::ReserveMessage;
bool ISourceBlock<T>.ReserveMessage (System.Threading.Tasks.Dataflow.DataflowMessageHeader messageHeader, System.Threading.Tasks.Dataflow.ITargetBlock<T> target);
abstract member System.Threading.Tasks.Dataflow.ISourceBlock<T>.ReserveMessage : System.Threading.Tasks.Dataflow.DataflowMessageHeader * System.Threading.Tasks.Dataflow.ITargetBlock<'T> -> bool
override this.System.Threading.Tasks.Dataflow.ISourceBlock<T>.ReserveMessage : System.Threading.Tasks.Dataflow.DataflowMessageHeader * System.Threading.Tasks.Dataflow.ITargetBlock<'T> -> bool
Function ReserveMessage (messageHeader As DataflowMessageHeader, target As ITargetBlock(Of T)) As Boolean Implements ISourceBlock(Of T).ReserveMessage
Parâmetros
- messageHeader
- DataflowMessageHeader
O DataflowMessageHeader da mensagem que é reservada.
- target
- ITargetBlock<T>
O ITargetBlock<TInput> que reserva a mensagem.
Retornos
true
se a mensagem foi reservada com êxito; caso contrário, false
.
Implementações
Exceções
O messageHeader
não é válido.
O target
é null
.
Comentários
Somente ITargetBlock<TInput> instâncias vinculadas a essa ISourceBlock<TOutput> instância podem ser usadas ReserveMessage, e ela só deve ser usada para reservar DataflowMessageHeader instâncias oferecidas anteriormente por essa origem para o destino.
Se true
for retornado, a ITargetBlock<TInput> mensagem deverá ser chamada ConsumeMessage posteriormente.ReleaseReservation Não fazer isso pode fazer com que a origem não possa propagar mais mensagens para esse ou outros destinos.
ReserveMessage não deve ser chamado enquanto o destino estiver mantendo bloqueios internos. Isso violará a hierarquia de bloqueio necessária para evitar deadlocks em uma rede de fluxo de dados.