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

Dieses Attribut anwenden, um die Einstiegspunktmethode (die Main() -Methode in c# und Visual Basic).Apply this attribute to the entry point method (the Main() method in C# and Visual Basic). Es hat keine Auswirkungen auf andere Methoden.It has no effect on other methods. Um den Apartmentzustand des Threads festgelegt, Sie in Ihrem Code starten, verwenden die Thread.SetApartmentState oder Thread.TrySetApartmentState 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-Threadmodell, finden Sie unter verstehen und Verwenden von COM-Threadingmodellen.For an overview of COM threading models, see Understanding and Using COM Threading Models.

Com-Threadingmodellen gelten nur für Anwendungen, die COM-Interop verwendet.COM threading models only apply to applications that use COM interop. Das COM-Threadingmodell kann auf Singlethread-Apartment oder Multithread-Apartment festgelegt werden.The COM threading model can be set to single-threaded apartment or multithreaded apartment. Thread der Anwendung 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 werden wurde, und die STAThreadAttribute -Attribut, wenn es vorhanden ist, hat keine Auswirkungen.If COM interop is not used, then the thread is not initialized, and the STAThreadAttribute attribute, if it is present, has no effect.

Ab .NET Framework, Version 2.0, hängt von der Standard-Threadingmodell für COM-Interop der Sprache, in der Sie Ihre Anwendung, wie die folgende Tabelle zeigt entwickeln.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 Singlethread-apartmentSingle-threaded apartment

Um diese Standardwerte zu ändern, verwenden Sie die STAThreadAttribute Attribut zum Festlegen des Threadingmodells für die Anwendung oder ein Aufruf der Thread.SetApartmentState oder Thread.TrySetApartmentState Methode vor dem Starten des Threads zum Festlegen des Threadingmodells für einen bestimmten Thread.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 /CLRTHREADATTRIBUTE Linkeroption, um das Apartmentmodell anzugeben.In C++, you can also use the /CLRTHREADATTRIBUTE linker option to specify the apartment model.

ASP.NET-Anwendungen sollten Festlegen der ASPCompat Attribut der @ Page -Direktive true auf der Seite durch den STA-Thread-Pool unterstützt werden.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.

Hier sind einige der Fälle, in dem sollten Sie verwenden, die STAThreadAttribute Attribut explizit das Threadingmodell auf Singlethread-Apartment festlegen: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:

  • Entwickeln Sie eine Windows Forms-app.You're developing a Windows Forms app. Windows Forms-apps muss Singlethread-Wenn sie mit Windows-Systemkomponenten wie die Zwischenablage oder eine Windows-Standarddialogfelder kommunizieren oder wenn sie Funktionen wie Drag & Drop-Funktionalität 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 Vorlage Windows Forms-Anwendung für C#-Code fügt automatisch die STAThreadAttribute -Attribut auf c#-Projekte.The Windows Forms Application template for C# automatically adds the STAThreadAttribute attribute to C# projects. Da das Singlethread-Apartment-Modell die Standardeinstellung für Visual Basic ist, besteht keine Notwendigkeit für das Attribut.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 verwendet.You're developing a C# app that calls a Visual Basic library, which, in turn, relies on COM interop. Da das Singlethread-Apartment-Modell die Standardeinstellung für Visual Basic ist, sollten Sie Ihrer app-threading-Modell in Singlethread-ändern, mit der STAThreadAttribute Attribut.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.

  • Die Anwendung aufruft, COM-Komponenten, die das Singlethread-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