Thread.SetApartmentState(ApartmentState) 메서드
정의
중요
일부 정보는 릴리스되기 전에 상당 부분 수정될 수 있는 시험판 제품과 관련이 있습니다. Microsoft는 여기에 제공된 정보에 대해 어떠한 명시적이거나 묵시적인 보증도 하지 않습니다.
스레드를 시작하기 전에 스레드의 아파트 상태를 설정합니다.
public:
void SetApartmentState(System::Threading::ApartmentState state);
[System.Runtime.Versioning.SupportedOSPlatform("windows")]
public void SetApartmentState (System.Threading.ApartmentState state);
public void SetApartmentState (System.Threading.ApartmentState state);
[<System.Runtime.Versioning.SupportedOSPlatform("windows")>]
member this.SetApartmentState : System.Threading.ApartmentState -> unit
member this.SetApartmentState : System.Threading.ApartmentState -> unit
Public Sub SetApartmentState (state As ApartmentState)
매개 변수
- state
- ApartmentState
새 아파트 상태입니다.
- 특성
예외
.NET Core 및 .NET 5 이상만 해당: macOS 및 Linux의 모든 경우에 해당합니다.
state
가 잘못된 아파트 상태가 아닙니다.
스레드가 이미 시작되었습니다.
아파트 상태가 이미 초기화되었습니다.
예제
다음 코드 예제에 설명 합니다 GetApartmentState SetApartmentState , , 및 TrySetApartmentState 메서드. 코드 예제에서는 스레드를 만듭니다. 스레드가 시작되기 전에 GetApartmentState 는 초기 ApartmentState.Unknown 상태를 표시하고 SetApartmentState 상태를 로 ApartmentState.STA 변경합니다. TrySetApartmentState그러면 아파트 false
상태가 이미 설정되어 있으므로 상태를 로 변경하려고 하면 메서드가 를 ApartmentState.MTA 반환합니다. 에서 동일한 작업을 시도한 경우 이 SetApartmentState InvalidOperationException throw됩니다.
스레드가 시작되면 TrySetApartmentState 메서드가 다시 사용됩니다. 이번에는 ThreadStateException 스레드가 이미 시작되었기 때문에 throw됩니다.
using namespace System;
using namespace System::Threading;
void ThreadProc()
{
Thread::Sleep(2000);
};
void main()
{
Thread^ t = gcnew Thread(gcnew ThreadStart(ThreadProc));
Console::WriteLine("Before setting apartment state: {0}",
t->GetApartmentState());
t->SetApartmentState(ApartmentState::STA);
Console::WriteLine("After setting apartment state: {0}",
t->GetApartmentState());
bool result = t->TrySetApartmentState(ApartmentState::MTA);
Console::WriteLine("Try to change state: {0}", result);
t->Start();
Thread::Sleep(500);
try
{
t->TrySetApartmentState(ApartmentState::STA);
}
catch (ThreadStateException^)
{
Console::WriteLine("ThreadStateException occurs " +
"if apartment state is set after starting thread.");
}
t->Join();
}
/* This code example produces the following output:
Before setting apartment state: Unknown
After setting apartment state: STA
Try to change state: False
ThreadStateException occurs if apartment state is set after starting thread.
*/
using System;
using System.Threading;
class Example
{
public static void Main()
{
Thread t = new Thread(ThreadProc);
Console.WriteLine("Before setting apartment state: {0}",
t.GetApartmentState());
t.SetApartmentState(ApartmentState.STA);
Console.WriteLine("After setting apartment state: {0}",
t.GetApartmentState());
bool result = t.TrySetApartmentState(ApartmentState.MTA);
Console.WriteLine("Try to change state: {0}", result);
t.Start();
Thread.Sleep(500);
try
{
t.TrySetApartmentState(ApartmentState.STA);
}
catch (ThreadStateException)
{
Console.WriteLine("ThreadStateException occurs " +
"if apartment state is set after starting thread.");
}
t.Join();
}
public static void ThreadProc()
{
Thread.Sleep(2000);
}
}
/* This code example produces the following output:
Before setting apartment state: Unknown
After setting apartment state: STA
Try to change state: False
ThreadStateException occurs if apartment state is set after starting thread.
*/
Imports System.Threading
Module Example
Sub Main()
Dim t As New Thread(AddressOf ThreadProc)
Console.WriteLine("Before setting apartment state: {0}", _
t.GetApartmentState())
t.SetApartmentState(ApartmentState.STA)
Console.WriteLine("After setting apartment state: {0}", _
t.GetApartmentState())
Dim result As Boolean = _
t.TrySetApartmentState(ApartmentState.MTA)
Console.WriteLine("Try to change state: {0}", result)
t.Start()
Thread.Sleep(500)
Try
t.TrySetApartmentState(ApartmentState.STA)
Catch ex As ThreadStateException
Console.WriteLine("ThreadStateException occurs " & _
"if apartment state is set after starting thread.")
End Try
t.Join()
End Sub
Sub ThreadProc()
Thread.Sleep(2000)
End Sub
End Module
' This code example produces the following output:
'
'Before setting apartment state: Unknown
'After setting apartment state: STA
'Try to change state: False
'ThreadStateException occurs if apartment state is set after starting thread.
설명
새 스레드는 아파트 ApartmentState.MTA 상태가 시작되기 전에 설정되지 않은 것처럼 초기화됩니다. 스레드가 시작되기 전에 아파트 상태를 설정해야 합니다.
참고
기본 애플리케이션 스레드가 초기화가 ApartmentState.MTA 기본적으로 합니다. 주 애플리케이션 스레드의 아파트 상태를 설정 하는 유일한 방법은 ApartmentState.STA 적용 하는 것은 STAThreadAttribute 진입점 메서드 특성입니다.
SetApartmentState메서드와 함께 GetApartmentState 메서드 및 TrySetApartmentState 메서드는 속성을 ApartmentState 대체합니다.