STAThreadAttribute STAThreadAttribute STAThreadAttribute STAThreadAttribute Class

Definition

Legt STA (Singlethreaded Apartment) als COM-Threadingmodell für Anwendungen fest.Indicates that the COM threading model for an application is single-threaded apartment (STA).

public ref class STAThreadAttribute sealed : Attribute
[System.AttributeUsage(System.AttributeTargets.Method)]
[System.Runtime.InteropServices.ComVisible(true)]
public sealed class STAThreadAttribute : Attribute
type STAThreadAttribute = class
    inherit Attribute
Public NotInheritable Class STAThreadAttribute
Inherits Attribute
Vererbung
STAThreadAttributeSTAThreadAttributeSTAThreadAttributeSTAThreadAttribute
Attribute

Hinweise

Wenden Sie dieses Attribut auf die Einstiegspunkt Methode an Main() (die C# -Methode in und Visual Basic).Apply this attribute to the entry point method (the Main() method in C# and Visual Basic). Dies hat keine Auswirkung auf andere Methoden.It has no effect on other methods. Um den Apartment Zustand von Threads festzulegen, die Sie im Code starten, Thread.SetApartmentState verwenden Thread.TrySetApartmentState Sie die-Methode oder die-Methode vor dem Starten des Threads.To set the apartment state of threads you start in your code, use the Thread.SetApartmentState or Thread.TrySetApartmentState method before starting the thread.

Hinweis

Eine Übersicht über COM-Threading Modelle finden Sie Untergrund Legendes und Verwenden von COM-Threading Modellen.For an overview of COM threading models, see Understanding and Using COM Threading Models.

Com-Threading Modelle gelten nur für Anwendungen, die COM-Interop verwenden.COM threading models only apply to applications that use COM interop. Das com-Threading Modell kann auf Single Thread-Apartment oder Multithread Apartment festgelegt werden.The COM threading model can be set to single-threaded apartment or multithreaded apartment. Der Anwendungs Thread wird nur für COM-Interop initialisiert, wenn der Thread tatsächlich eine COM-Komponente aufruft.The application thread is only initialized for COM interop if the thread actually makes a call to a COM component. Wenn COM-Interop nicht verwendet wird, wird der Thread nicht initialisiert, und das STAThreadAttribute -Attribut hat keine Auswirkung, wenn es vorhanden ist.If COM interop is not used, then the thread is not initialized, and the STAThreadAttribute attribute, if it is present, has no effect.

Beginnend mit der .NET Framework Version 2,0, hängt das Standard Threading Modell für COM-Interop von der Sprache ab, in der Sie Ihre Anwendung entwickeln, wie in der folgenden Tabelle gezeigt.Starting with the .NET Framework version 2.0, the default threading model for COM interop depends on the language in which you are developing your application, as the following table shows.

SpracheLanguage COM-Apartment ModellCOM apartment model
C#C# Multithread-ApartmentMultithreaded apartment
C++C++ Multithread-ApartmentMultithreaded apartment
Visual BasicVisual Basic Single Thread-ApartmentSingle-threaded apartment

Um diese Standardwerte zu ändern, verwenden STAThreadAttribute Sie das-Attribut, um das Threading Modell für die Anwendung fest Thread.SetApartmentState zulegen Thread.TrySetApartmentState , oder bevor Sie den Thread starten, um das Threading Modell für einen bestimmten Thread festzulegen.To change these defaults, you use the STAThreadAttribute attribute to set the threading model for the application, or call the Thread.SetApartmentState or Thread.TrySetApartmentState method before starting the thread to set the threading model for a particular thread. In C++können Sie auch die Option /CLRTHREADATTRIBUTE Linker verwenden, um das Apartment Modell anzugeben.In C++, you can also use the /CLRTHREADATTRIBUTE linker option to specify the apartment model.

ASP.NET-Anwendungen sollten das ASPCompat -Attribut der @ Page -Direktive auf true festlegen, um das Warten der Seite durch den STA-Thread Pool zu erzwingen.ASP.NET applications should set the ASPCompat attribute of the @ Page directive to true to force the page to be serviced by the STA thread pool.

Im folgenden finden Sie einige der Fälle, in denen Sie das STAThreadAttribute -Attribut verwenden möchten, um das Threading Modell explizit auf Single Thread-Apartment festzulegen:Here are some of the cases in which you'll want to use the STAThreadAttribute attribute to explicitly set the threading model to single-threaded apartment:

  • Sie entwickeln eine Windows Forms-app.You're developing a Windows Forms app. Windows Forms-apps müssen einen Single Thread aufweisen, wenn Sie mit Windows-Systemkomponenten wie z. b. der Zwischenablage oder den allgemeinen Windows-Dialogfeldern kommunizieren, oder wenn Sie Systemfunktionen wie Drag & Drop-Funktionen verwenden.Windows Forms apps must be single-threaded if they communicate with Windows system components such as the Clipboard or Windows common dialog boxes, or if they use system features such as drag-and-drop functionality. Die Windows Forms-Anwendungs Vorlage C# für fügt den STAThreadAttribute C# Projekten automatisch das-Attribut hinzu.The Windows Forms Application template for C# automatically adds the STAThreadAttribute attribute to C# projects. Da das Single Thread-Apartment Modell der Standardwert für Visual Basic ist, ist das-Attribut nicht erforderlich.Because the single-threaded apartment model is the default for Visual Basic, there is no need for the attribute.

  • Sie entwickeln eine C# APP, die eine Visual Basic Bibliothek aufruft, die wiederum auf COM-Interop basiert.You're developing a C# app that calls a Visual Basic library, which, in turn, relies on COM interop. Da das Single Thread-Apartment Modell der Standardwert für Visual Basic ist, müssen Sie das Threading Modell Ihrer APP in Single Thread mithilfe des STAThreadAttribute -Attributs ändern.Because the single-threaded apartment model is the default for Visual Basic, you should change your app's threading model to single-threaded by using the STAThreadAttribute attribute.

  • Ihre Anwendung führt Aufrufe an COM-Komponenten aus, die das Single Thread-Apartment Modell verwenden.Your application makes calls to COM components that use the single-threaded apartment model.

Konstruktoren

STAThreadAttribute() STAThreadAttribute() STAThreadAttribute() STAThreadAttribute()

Initialisiert eine neue Instanz der STAThreadAttribute-Klasse.Initializes a new instance of the STAThreadAttribute class.

Methoden

Equals(Object) Equals(Object) Equals(Object) Equals(Object)

Gibt einen Wert zurück, der angibt, ob diese Instanz gleich einem angegebenen Objekt ist.Returns a value that indicates whether this instance is equal to a specified object.

(Inherited from Attribute)
GetHashCode() GetHashCode() GetHashCode() GetHashCode()

Gibt den Hashcode für diese Instanz zurück.Returns the hash code for this instance.

(Inherited from Attribute)
GetType() GetType() GetType() GetType()

Ruft den Type der aktuellen Instanz ab.Gets the Type of the current instance.

(Inherited from Object)
IsDefaultAttribute() IsDefaultAttribute() IsDefaultAttribute() IsDefaultAttribute()

Gibt beim Überschreiben in einer abgeleiteten Klasse an, ob der Wert der Instanz der Standardwert für die abgeleitete Klasse ist.When overridden in a derived class, indicates whether the value of this instance is the default value for the derived class.

(Inherited from Attribute)
Match(Object) Match(Object) Match(Object) Match(Object)

Beim Überschreiben in einer abgeleiteten Klasse wird ein Wert zurückgegeben, der angibt, ob diese Instanz einem bestimmten Objekt entspricht.When overridden in a derived class, returns a value that indicates whether this instance equals a specified object.

(Inherited from Attribute)
MemberwiseClone() MemberwiseClone() MemberwiseClone() MemberwiseClone()

Erstellt eine flache Kopie des aktuellen Object.Creates a shallow copy of the current Object.

(Inherited from Object)
ToString() ToString() ToString() ToString()

Gibt eine Zeichenfolge zurück, die das aktuelle Objekt darstellt.Returns a string that represents the current object.

(Inherited from Object)

Explizite Schnittstellenimplementierungen

_Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr) _Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr) _Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr) _Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr)

Ordnet eine Reihe von Namen einer entsprechenden Reihe von Dispatchbezeichnern zu.Maps a set of names to a corresponding set of dispatch identifiers.

(Inherited from Attribute)
_Attribute.GetTypeInfo(UInt32, UInt32, IntPtr) _Attribute.GetTypeInfo(UInt32, UInt32, IntPtr) _Attribute.GetTypeInfo(UInt32, UInt32, IntPtr) _Attribute.GetTypeInfo(UInt32, UInt32, IntPtr)

Ruft die Typinformationen für ein Objekt ab, mit deren Hilfe die Typinformationen für eine Schnittstelle abgerufen werden können.Retrieves the type information for an object, which can be used to get the type information for an interface.

(Inherited from Attribute)
_Attribute.GetTypeInfoCount(UInt32) _Attribute.GetTypeInfoCount(UInt32) _Attribute.GetTypeInfoCount(UInt32) _Attribute.GetTypeInfoCount(UInt32)

Ruft die Anzahl der Schnittstellen mit Typinformationen ab, die von einem Objekt bereitgestellt werden (0 oder 1).Retrieves the number of type information interfaces that an object provides (either 0 or 1).

(Inherited from Attribute)
_Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr) _Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr) _Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr) _Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr)

Stellt den Zugriff auf von einem Objekt verfügbar gemachte Eigenschaften und Methoden bereit.Provides access to properties and methods exposed by an object.

(Inherited from Attribute)

Eigenschaften

TypeId TypeId TypeId TypeId

Ruft bei Implementierung in einer abgeleiteten Klasse einen eindeutigen Bezeichner für dieses Attribute ab.When implemented in a derived class, gets a unique identifier for this Attribute.

(Inherited from Attribute)

Gilt für:

Siehe auch