다음을 통해 공유


Thread.SetApartmentState(ApartmentState) 메서드

정의

스레드를 시작하기 전에 스레드의 아파트 상태를 설정합니다.

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 대체합니다.

적용 대상