다음을 통해 공유


System.Threading 네임스페이스

System.Threading, System.Threading.Tasks 및 System.Threading.Tasks.DataFlow 네임스페이스에는 다중 스레드 프로그래밍을 가능하게 하고 동시 및 비동기 코드 작성을 단순화하는 형식이 포함되어 있습니다.

이 항목에서는 Windows 스토어 앱용 .NET에 포함되거나 설치하여 Windows 스토어 응용 프로그램을 만드는 데 사용할 수 있는 System.Threading, System.Threading.Tasks 및 System.Threading.Tasks.DataFlow 네임스페이스의 형식을 보여 줍니다.Windows 스토어 앱용 .NET에는 각 형식의 일부 멤버만 포함되어 있습니다.개별 형식에 대한 자세한 내용은 링크된 항목을 참조하십시오.형식에 대한 설명서는 Windows 스토어 앱용 .NET에 포함된 멤버를 나타냅니다.

System.Threading.Tasks.Dataflow 네임스페이스를 설치하려면 Visual Studio 2012에서 프로젝트를 열고 프로젝트 메뉴에서 NuGet 패키지 관리를 선택한 다음 Microsoft.Tpl.Dataflow 패키지를 온라인으로 검색합니다.

System.Threading 네임스페이스

Windows 스토어 앱용 .NET에서 지원되는 형식

설명

AbandonedMutexException

스레드가 다른 스레드에서 해제하지 않고 종료하여 중단한 Mutex 개체를 가져오면 throw되는 예외입니다.

AutoResetEvent

대기 중인 스레드에 이벤트가 발생했음을 알립니다.이 클래스는 상속될 수 없습니다.

Barrier

여러 작업이 여러 단계에 걸쳐 특정 알고리즘에서 병렬로 함께 작동할 수 있도록 합니다.

BarrierPostPhaseException

Barrier의 사후 단계 작업이 실패할 경우 throw되는 예외입니다.

CancellationToken

작업을 취소하지 않아야 함을 전파합니다.

CancellationTokenRegistration

CancellationToken에 등록된 콜백 대리자를 나타냅니다.

CancellationTokenSource

취소되도록 CancellationToken에 신호를 보냅니다.

CountdownEvent

수가 0에 도달하는 경우 신호를 받는 동기화 기본 형식을 나타냅니다.

EventResetMode

EventWaitHandle이 신호를 받은 후 자동으로 다시 설정되는지 아니면 수동으로 다시 설정되는지를 나타냅니다.

EventWaitHandle

스레드 동기화 이벤트를 나타냅니다.

Interlocked

다중 스레드에서 공유하는 변수에 대한 원자 단위 연산을 제공합니다.

LazyInitializer

초기화 지연 루틴을 제공합니다.

LazyThreadSafetyMode

Lazy<T> 인스턴스가 여러 스레드 간 액세스를 동기화하는 방법을 지정합니다.

LockRecursionException

잠금에 대한 재귀 정책과 맞지 않는 방식으로 잠금을 재귀적으로 시작할 때 throw되는 예외입니다.

LockRecursionPolicy

동일한 스레드에서 잠금을 여러 번 시작할 수 있는지 여부를 지정합니다.

ManualResetEvent

하나 이상의 대기 중인 스레드에 이벤트가 발생했음을 알립니다.이 클래스는 상속될 수 없습니다.

ManualResetEventSlim

ManualResetEvent의 슬림 다운 버전을 제공합니다.

Monitor

개체에 대한 액세스를 동기화하는 메커니즘을 제공합니다.

Mutex

프로세스 간 동기화에 사용할 수도 있는 동기화 기본 형식입니다.

ReaderWriterLockSlim

여러 스레드에서 읽을 수 있도록 허용하거나 쓰기를 위한 단독 액세스를 허용하여 리소스에 대한 액세스를 관리하는 데 사용되는 잠금을 나타냅니다.

Semaphore

리소스 또는 리소스 풀에 동시에 액세스할 수 있는 스레드 수를 제한합니다.

SemaphoreFullException

카운트가 이미 최대값에 도달한 세마포에 대해 Release 메서드를 호출한 경우 throw되는 예외입니다.

SemaphoreSlim

리소스 또는 리소스 풀에 동시에 액세스할 수 있는 스레드 수를 제한하는 Semaphore 대신 사용할 수 있는 간단한 클래스입니다.

SendOrPostCallback

메시지가 동기화 컨텍스트로 디스패치될 때 호출할 메서드를 나타냅니다.

SpinLock

잠금을 얻으려는 스레드가 잠금을 사용할 수 있을 때까지 루프에서 반복적으로 확인하면서 대기하는 기본적인 상호 배타 잠금을 제공합니다.

SpinWait

회전 기반 대기를 지원합니다.

SynchronizationContext

다양한 동기화 모델에서 동기화 컨텍스트를 전파하기 위한 기본 기능을 제공합니다.

SynchronizationLockException

메서드가 지정된 Monitor에 대해 잠금을 소유하도록 호출자에게 요구하지만 해당 잠금을 소유하지 않는 호출자가 해당 메서드를 호출할 때 throw되는 예외입니다.

ThreadLocal<T>

데이터의 스레드 로컬 저장소를 제공합니다.

Timeout

무한 시간 제한 간격을 지정하는 상수를 포함합니다.이 클래스는 상속될 수 없습니다.

Volatile

휘발성 메모리 작업을 수행하기 위한 메서드를 포함합니다.

WaitHandle

공유 리소스에 대한 단독 액세스를 기다리는 운영 체제 관련 개체를 캡슐화합니다.

WaitHandleCannotBeOpenedException

존재하지 않는 시스템 뮤텍스 또는 세마포를 열려고 할 때 throw되는 예외입니다.

System.Threading.Tasks 네임스페이스

Windows 스토어 앱용 .NET에서 지원되는 형식

설명

ConcurrentExclusiveSchedulerPair

동시 작업을 동시에 실행하고 전용 작업은 실행하지 않으면서 작업을 실행하도록 조정하는 동시 및 전용 작업 스케줄러를 제공합니다.

Parallel

병렬 루프 및 영역에 대한 지원을 제공합니다.

ParallelLoopResult

병렬 루프의 실행에 대한 완료 상태를 제공합니다.

ParallelLoopState

Parallel 루프의 반복이 다른 반복과 상호 작용할 수 있도록 합니다.이 클래스의 인스턴스는 Parallel 클래스에 의해 각 루프에 제공됩니다. 사용자 코드에 인스턴스를 만들 수는 없습니다.

ParallelOptions

Parallel 클래스의 메서드 작업을 구성하는 옵션을 저장합니다.

Task

비동기 작업을 나타냅니다.

Task<TResult>

값을 반환할 수 있는 비동기 작업을 나타냅니다.

TaskCanceledException

작업 취소를 전달하는 데 사용되는 예외를 나타냅니다.

TaskCompletionSource<TResult>

대리자에 바인딩되지 않은 Task<TResult>의 생산자 측면을 나타내고 TaskCompletionSource<T>.Task 속성을 통해 소비자 측면에 대한 액세스를 제공합니다.

TaskContinuationOptions

ContinueWith 또는 Task<T>.ContinueWith 메서드를 사용하여 만드는 작업의 동작을 지정합니다.

TaskCreationOptions

작업을 만들고 실행하기 위한 선택적 동작을 제어하는 플래그를 지정합니다.

TaskExtensions

특정 유형의 Task 인스턴스로 작업하기 위한 static(Visual Basic의 경우 Shared) 메서드 집합을 제공합니다.

TaskFactory

Task 개체를 만들고 예약하도록 지원합니다.

TaskFactory<TResult>

Task<T> 개체를 만들고 예약하도록 지원합니다.

TaskScheduler

작업을 스레드의 큐에 대기하는 낮은 수준의 작업을 처리하는 개체를 나타냅니다.

TaskSchedulerException

TaskScheduler에서 잘못된 작업을 알리는 데 사용되는 예외를 나타냅니다.

TaskStatus

작업의 수명 주기에서 현재 단계를 나타냅니다.

UnobservedTaskExceptionEventArgs

오류가 발생한 작업의 예외가 관찰되지 않을 때 발생하는 이벤트에 대한 데이터를 제공합니다.

System.Threading.Tasks.DataFlow 네임스페이스

System.Threading.Tasks.Dataflow 네임스페이스를 설치하려면 Visual Studio 2012에서 프로젝트를 열고 프로젝트 메뉴에서 NuGet 패키지 관리를 선택한 다음 Microsoft.Tpl.Dataflow 패키지를 온라인으로 검색합니다.

Windows 스토어 앱용 .NET에서 지원되는 형식

설명

ActionBlock<TInput>

수신한 모든 데이터 요소에 대해 제공된 Action<T> 대리자를 호출하는 데이터 흐름 블록을 제공합니다.

BatchBlock<T>

배열로 입력을 일괄 처리하는 데이터 흐름 블록을 제공합니다.

BatchedJoinBlock<T1, T2>

하나 이상의 대상에 제공되어 차이가 있을 수 있는 형식에 대한 지정한 수의 입력을 일괄 처리하는 데이터 흐름 블록을 제공합니다.

BatchedJoinBlock<T1, T2, T3>

하나 이상의 대상에 제공되어 차이가 있을 수 있는 형식에 대한 지정한 수의 입력을 일괄 처리하는 데이터 흐름 블록을 제공합니다.

BroadcastBlock<T>

최대 한 개의 요소를 한 번에 저장하고 각 메시지가 도착하면 다음 메시지로 덮어쓰기 위한 버퍼를 제공합니다.메시지는 연결된 모든 대상으로 브로드캐스팅되며, 모든 대상은 메시지의 복제본을 사용할 수 있습니다.

BufferBlock<T>

데이터 저장을 위한 버퍼를 제공합니다.

DataflowBlock

데이터 흐름 블록으로 작업하기 위한 static(Visual Basic의 경우 Shared) 메서드 집합을 제공합니다.

DataflowBlockOptions

데이터 흐름 블록에서 수행하는 처리를 구성하는 데 사용되는 옵션을 제공합니다.

DataflowLinkOptions

데이터 흐름 블록 사이의 링크를 구성하는 데 사용되는 옵션을 제공합니다.

DataflowMessageHeader

데이터 흐름 블록 간 전달을 위한 데이터 특성의 컨테이너를 제공합니다.

DataflowMessageStatus

데이터 흐름 블록 간에 전달될 때 DataflowMessageHeader의 상태를 나타냅니다.

ExecutionDataflowBlockOptions

사용자가 제공한 대리자의 호출을 통해 각 메시지를 처리하는 데이터 흐름 블록에 의해 수행되는 처리를 구성하는 데 사용되는 옵션을 제공합니다.ActionBlock<TInput>, TransformBlock<TInput, TOutput> 등의 데이터 흐름 블록입니다.

GroupingDataflowBlockOptions

여러 개의 메시지를 그룹화하는 데이터 흐름 블록에 의해 수행되는 처리를 구성하는 데 사용되는 옵션을 제공합니다.JoinBlock<T1, T2>, BatchBlock<T> 등의 데이터 흐름 블록입니다.

IDataflowBlock

데이터 흐름 블록을 나타냅니다.

IPropagatorBlock<TInput, TOutput>

데이터의 대상 및 소스인 데이터 흐름 블록을 나타냅니다.

IReceivableSourceBlock<TOutput>

링크하지 않고 수신 메시지를 지원하는 데이터 흐름 블록을 나타냅니다.

ISourceBlock<TOutput>

데이터의 소스인 데이터 흐름 블록을 나타냅니다.

ITargetBlock<TInput>

데이터의 대상인 데이터 흐름 블록을 나타냅니다.

JoinBlock<T1, T2>

형식당 하나의 항목을 포함하는 튜플로서 모두 함께 릴리스되기 전에 각 형식이 도착할 때까지 한 항목을 기다리는 과정으로, 여러 데이터 흐름 소스 간에 연결하는 데이터 흐름 블록을 제공합니다. 이 경우 소스는 같은 유형이 아닐 수도 있습니다.

JoinBlock<T1, T2, T3>

형식당 하나의 항목을 포함하는 튜플로서 모두 함께 릴리스되기 전에 각 형식이 도착할 때까지 한 항목을 기다리는 과정으로, 여러 데이터 흐름 소스 간에 연결하는 데이터 흐름 블록을 제공합니다. 이 경우 소스는 같은 유형이 아닐 수도 있습니다.

TransformBlock<TInput, TOutput>

수신한 모든 데이터 요소에 대해 제공된 Func<T, TResult> 대리자를 호출하는 데이터 흐름 블록을 제공합니다.

TransformManyBlock<TInput, TOutput>

수신한 모든 데이터 요소에 대해 제공된 Func<T, TResult> 대리자를 호출하는 데이터 흐름 블록을 제공합니다.

WriteOnceBlock<T>

데이터 흐름 블록의 네트워크에서 최대 하나의 요소를 수신 및 저장하기 위한 버퍼를 제공합니다.

참고 항목

개념

Windows 스토어 앱용 .NET - 지원되는 API