다음을 통해 공유


BroadcastBlock<T> 클래스

정의

최대 한 개의 요소를 한 번에 저장하고 각 메시지가 도착하면 다음 메시지로 덮어쓰기 위한 버퍼를 제공합니다.

generic <typename T>
public ref class BroadcastBlock sealed : System::Threading::Tasks::Dataflow::IPropagatorBlock<T, T>, System::Threading::Tasks::Dataflow::IReceivableSourceBlock<T>, System::Threading::Tasks::Dataflow::ISourceBlock<T>, System::Threading::Tasks::Dataflow::ITargetBlock<T>
public sealed class BroadcastBlock<T> : System.Threading.Tasks.Dataflow.IPropagatorBlock<T,T>, System.Threading.Tasks.Dataflow.IReceivableSourceBlock<T>, System.Threading.Tasks.Dataflow.ISourceBlock<T>, System.Threading.Tasks.Dataflow.ITargetBlock<T>
type BroadcastBlock<'T> = class
    interface IPropagatorBlock<'T, 'T>
    interface ITargetBlock<'T>
    interface IDataflowBlock
    interface ISourceBlock<'T>
    interface IReceivableSourceBlock<'T>
type BroadcastBlock<'T> = class
    interface IDataflowBlock
    interface IPropagatorBlock<'T, 'T>
    interface ISourceBlock<'T>
    interface ITargetBlock<'T>
    interface IReceivableSourceBlock<'T>
Public NotInheritable Class BroadcastBlock(Of T)
Implements IPropagatorBlock(Of T, T), IReceivableSourceBlock(Of T), ISourceBlock(Of T), ITargetBlock(Of T)

형식 매개 변수

T

이 데이터 흐름 블록으로 버퍼링된 데이터 형식을 지정합니다.

상속
BroadcastBlock<T>
구현

설명

참고

TPL 데이터 흐름 라이브러리(System.Threading.Tasks.Dataflow 네임스페이스)는 .NET과 함께 배포되지 않습니다. Visual Studio에서 System.Threading.Tasks.Dataflow 네임스페이스를 설치하려면 프로젝트를 열고, 프로젝트 메뉴에서 NuGet 패키지 관리를 선택한 후, System.Threading.Tasks.Dataflow 패키지를 온라인으로 검색합니다. 또는 .NET Core CLI를 사용하여 설치하려면 dotnet add package System.Threading.Tasks.Dataflow를 실행합니다.

BroadcastBlock<T> 는 한 번에 최대 하나의 요소를 노출합니다. 그러나 블록에 WriteOnceBlock<T>새 요소가 제공되면 해당 요소를 덮어씁니다. BroadcastBlock<T> 는 요소를 덮어쓰도록 허용하기 전에 현재 요소가 연결된 대상에 브로드캐스트되도록 합니다.

생성자

BroadcastBlock<T>(Func<T,T>)

지정된 복제 함수를 사용하여 BroadcastBlock<T>을 초기화합니다.

BroadcastBlock<T>(Func<T,T>, DataflowBlockOptions)

지정된 복제 함수 및 DataflowBlockOptions를 사용하여 BroadcastBlock<T>을 초기화합니다.

속성

Completion

비동기 작업 및 데이터 흐름 블록의 완료를 나타내는 Task를 가져옵니다.

메서드

Complete()

IDataflowBlock에 대한 신호를 통해 더 이상의 메시지를 받거나 생성할 수 없으며 추가로 지연된 메시지를 사용하면 안 됩니다.

Equals(Object)

지정된 개체가 현재 개체와 같은지 확인합니다.

(다음에서 상속됨 Object)
GetHashCode()

기본 해시 함수로 작동합니다.

(다음에서 상속됨 Object)
GetType()

현재 인스턴스의 Type을 가져옵니다.

(다음에서 상속됨 Object)
LinkTo(ITargetBlock<T>, DataflowLinkOptions)

ISourceBlock<TOutput>을 지정된 ITargetBlock<TInput>에 연결합니다.

MemberwiseClone()

현재 Object의 단순 복사본을 만듭니다.

(다음에서 상속됨 Object)
ToString()

IDataflowBlock 인스턴스의 형식 지정된 이름을 나타내는 문자열을 반환합니다.

TryReceive(Predicate<T>, T)

IReceivableSourceBlock<TOutput>에서 사용 가능한 출력 항목을 비동기적으로 받으려고 시도합니다.

명시적 인터페이스 구현

IDataflowBlock.Fault(Exception)

IDataflowBlock 상태에서 Faulted가 완료되도록 합니다.

IReceivableSourceBlock<T>.TryReceiveAll(IList<T>)

IReceivableSourceBlock<TOutput>에서 모든 사용 가능한 항목을 비동기적으로 받으려고 시도합니다.

ISourceBlock<T>.ConsumeMessage(DataflowMessageHeader, ITargetBlock<T>, Boolean)

ITargetBlock<TInput>에서 이전에 제공한 DataflowMessageHeader를 받아 사용하기 위해 연결된 ISourceBlock<TOutput>에 의해 호출됩니다.

ISourceBlock<T>.ReleaseReservation(DataflowMessageHeader, ITargetBlock<T>)

ITargetBlock<TInput>에 의해 이전에 예약한 DataflowMessageHeader를 해제하기 위해 연결된 ISourceBlock<TOutput>에 의해 호출됩니다.

ISourceBlock<T>.ReserveMessage(DataflowMessageHeader, ITargetBlock<T>)

ITargetBlock<TInput>에 의해 이전에 제공한 DataflowMessageHeader를 예약하기 위해 연결된 ISourceBlock<TOutput>에 의해 호출됩니다.

ITargetBlock<T>.OfferMessage(DataflowMessageHeader, T, ISourceBlock<T>, Boolean)

메시지를 ITargetBlock<TInput>에 제공하며 대상에서 메시지를 선택적으로 사용하거나 연기할 수 있습니다.

확장 메서드

AsObservable<TOutput>(ISourceBlock<TOutput>)

IObservable<T> 위에 새 ISourceBlock<TOutput> 추상화를 만듭니다.

AsObserver<TInput>(ITargetBlock<TInput>)

ITargetBlock<TInput> 위에 새 IObserver<T> 추상화를 만듭니다.

LinkTo<TOutput>(ISourceBlock<TOutput>, ITargetBlock<TOutput>)

ISourceBlock<TOutput>을 지정된 ITargetBlock<TInput>에 연결합니다.

LinkTo<TOutput>(ISourceBlock<TOutput>, ITargetBlock<TOutput>, Predicate<TOutput>)

지정된 필터를 사용하여 ISourceBlock<TOutput>을 지정된 ITargetBlock<TInput>에 연결합니다.

LinkTo<TOutput>(ISourceBlock<TOutput>, ITargetBlock<TOutput>, DataflowLinkOptions, Predicate<TOutput>)

지정된 필터를 사용하여 ISourceBlock<TOutput>을 지정된 ITargetBlock<TInput>에 연결합니다.

OutputAvailableAsync<TOutput>(ISourceBlock<TOutput>)

사용 가능한 출력에 대한 소스를 비동기적으로 모니터링하는 Task<TResult>을 제공합니다.

OutputAvailableAsync<TOutput>(ISourceBlock<TOutput>, CancellationToken)

사용 가능한 출력에 대한 소스를 비동기적으로 모니터링하는 Task<TResult>을 제공합니다.

Post<TInput>(ITargetBlock<TInput>, TInput)

ITargetBlock<TInput>에 항목을 게시합니다.

Receive<TOutput>(ISourceBlock<TOutput>)

지정된 소스에서 값을 동기적으로 받습니다.

Receive<TOutput>(ISourceBlock<TOutput>, CancellationToken)

지정된 소스에서 값을 동기적으로 받고 작업을 취소하는 토큰을 제공합니다.

Receive<TOutput>(ISourceBlock<TOutput>, TimeSpan)

지정된 소스에서 값을 동기적으로 받으며 최적의 시간 초과 기간을 관찰합니다.

Receive<TOutput>(ISourceBlock<TOutput>, TimeSpan, CancellationToken)

지정된 원본에서 값을 동기적으로 받으면서 작업을 취소하는 토큰을 제공하고 최적의 시간 초과 간격을 관찰합니다.

ReceiveAllAsync<TOutput>(IReceivableSourceBlock<TOutput>, CancellationToken)

IAsyncEnumerable<T> 원본에서 모든 데이터를 수신할 수 있는 해당 데이터를 만듭니다.

ReceiveAsync<TOutput>(ISourceBlock<TOutput>)

지정된 소스에서 값을 비동기적으로 받습니다.

ReceiveAsync<TOutput>(ISourceBlock<TOutput>, CancellationToken)

지정된 소스에서 값을 비동기적으로 받고 작업을 취소하는 토큰을 제공합니다.

ReceiveAsync<TOutput>(ISourceBlock<TOutput>, TimeSpan)

지정된 소스에서 값을 비동기적으로 받으며 최적의 시간 초과 기간을 관찰합니다.

ReceiveAsync<TOutput>(ISourceBlock<TOutput>, TimeSpan, CancellationToken)

지정된 원본에서 값을 비동기적으로 받으면서 작업을 취소하는 토큰을 제공하고 최적의 시간 초과 간격을 관찰합니다.

SendAsync<TInput>(ITargetBlock<TInput>, TInput)

대상 메시지 블록에 메시지를 비동기적으로 제공하며, 연기를 허용합니다.

SendAsync<TInput>(ITargetBlock<TInput>, TInput, CancellationToken)

대상 메시지 블록에 메시지를 비동기적으로 제공하며, 연기를 허용합니다.

TryReceive<TOutput>(IReceivableSourceBlock<TOutput>, TOutput)

ISourceBlock<TOutput>에서 항목을 비동기적으로 받으려고 시도합니다.

적용 대상