Поделиться через


BufferBlock<T>.ISourceBlock<T>.ReserveMessage Метод

Определение

Вызывается связанным объектом ITargetBlock<TInput> для резервирования объекта DataflowMessageHeader, ранее предложенного этим объектом 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

Параметры

messageHeader
DataflowMessageHeader

Объект DataflowMessageHeader резервируемого сообщения.

target
ITargetBlock<T>

ITargetBlock<TInput>, сохраняющий сообщение.

Возвращаемое значение

Значение true, если сообщение было успешно зарезервировано; в противном случае — значение false.

Реализации

Исключения

Недопустимое значение messageHeader.

Значение параметра targetnull.

Комментарии

Только ITargetBlock<TInput> экземпляры, связанные с этим ISourceBlock<TOutput> экземпляром, могут использовать ReserveMessage, и он должен использоваться только для резервирования DataflowMessageHeader экземпляров, ранее предлагаемых этим источником для целевого объекта.

Если true возвращается , ITargetBlock<TInput> объект должен впоследствии вызвать или ConsumeMessageReleaseReservation для этого сообщения. Невыполнение этого действия может привести к тому, что источник не сможет распространить дополнительные сообщения на этот или другие целевые объекты.

ReserveMessage не должен вызываться, когда целевой объект удерживает какие-либо внутренние блокировки. Это приведет к нарушению иерархии блокировок, необходимой для предотвращения взаимоблокировок в сети потока данных.

Применяется к