ISourceBlock<TOutput>.ReserveMessage 메서드
정의
중요
일부 정보는 릴리스되기 전에 상당 부분 수정될 수 있는 시험판 제품과 관련이 있습니다. Microsoft는 여기에 제공된 정보에 대해 어떠한 명시적이거나 묵시적인 보증도 하지 않습니다.
이 ITargetBlock<TInput>에 의해 이전에 제공한 DataflowMessageHeader를 예약하기 위해 연결된 ISourceBlock<TOutput>에 의해 호출됩니다.
public:
bool ReserveMessage(System::Threading::Tasks::Dataflow::DataflowMessageHeader messageHeader, System::Threading::Tasks::Dataflow::ITargetBlock<TOutput> ^ target);
public bool ReserveMessage (System.Threading.Tasks.Dataflow.DataflowMessageHeader messageHeader, System.Threading.Tasks.Dataflow.ITargetBlock<out TOutput> target);
abstract member ReserveMessage : System.Threading.Tasks.Dataflow.DataflowMessageHeader * System.Threading.Tasks.Dataflow.ITargetBlock<'Output> -> bool
Public Function ReserveMessage (messageHeader As DataflowMessageHeader, target As ITargetBlock(Of Out TOutput)) As Boolean
매개 변수
- messageHeader
- DataflowMessageHeader
받고 있는 메시지의 DataflowMessageHeader입니다.
- target
- ITargetBlock<TOutput>
메시지를 예약하는 ITargetBlock<TInput>입니다.
반환
메시지를 성공적으로 예약했으면 true
이고, 그렇지 않으면 false
입니다.
예외
messageHeader
이 올바르지 않은 경우
target
이 null
인 경우
설명
만 ITargetBlock<TInput> 이 연결 된 인스턴스 ISourceBlock<TOutput> 인스턴스를 사용할 수 있습니다 ReserveMessage, 예약에 사용 해야 합니다 DataflowMessageHeader 인스턴스가이 원본을 대상으로 이전에 제공 합니다.
하는 경우 true
반환 되는 ITargetBlock<TInput> 호출 이후에 해야 ConsumeMessage 또는 ReleaseReservation 이 메시지에 대 한 합니다. 이렇게 하지 않으면이 또는 다른 대상에 메시지를 더 이상 전달할 수 없는 소스에서 발생할 수 있습니다.
ReserveMessage 대상 유지 하는 동안 내부 잠금을 하지 호출 해야 합니다. 이렇게 위반 잠금 계층 구조의 데이터 흐름 네트워크에서 교착 상태를 방지 하기 위해 필요 합니다.