MTAThreadAttribute MTAThreadAttribute MTAThreadAttribute MTAThreadAttribute Class

Definition

Legt MTA (Multithreaded Apartment) als COM-Threadingmodell für Anwendungen fest.Indicates that the COM threading model for an application is multithreaded apartment (MTA).

public ref class MTAThreadAttribute sealed : Attribute
[System.AttributeUsage(System.AttributeTargets.Method)]
[System.Runtime.InteropServices.ComVisible(true)]
public sealed class MTAThreadAttribute : Attribute
type MTAThreadAttribute = class
    inherit Attribute
Public NotInheritable Class MTAThreadAttribute
Inherits Attribute
Vererbung
MTAThreadAttributeMTAThreadAttributeMTAThreadAttributeMTAThreadAttribute
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 MTAThreadAttribute -Attribut, wenn es vorhanden ist, hat keine Auswirkungen.If COM interop is not used, then the thread is not initialized, and the MTAThreadAttribute 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 MTAThreadAttribute 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 MTAThreadAttribute 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 (festlegen CLR-Threadattributs) Linkeroption, um das Apartmentmodell anzugeben.In C++, you can also use the /CLRTHREADATTRIBUTE (Set CLR Thread Attribute) linker option to specify the apartment model.

Einige Fälle, in dem Sie verwenden möchten, die MTAThreadAttribute Attribut explizit das Threadingmodell auf Multithread-Apartment umfassen Folgendes:Some of the cases in which you want to use the MTAThreadAttribute attribute to explicitly set the threading model to multithreaded apartment include the following:

  • Entwickeln Sie eine Visual Basic-Anwendungen, die in einer c#-Bibliothek aufruft, das wiederum auf COM-Interop basiert.You're developing a Visual Basic app that calls to a C# library that in turn relies on COM interop. Da das Multithread-Apartment-Modell die Standardeinstellung für C#-Code ist, sollten Sie Ihrer app-threading-Modell in Multithread ändern, mit der MTAThreadAttribute Attribut.Because the multithreaded apartment model is the default for C#, you should change your app's threading model to multithreaded by using the MTAThreadAttribute attribute.

  • Die Anwendung aufruft, COM-Komponenten, die die Multithread-Apartment-Modell verwenden.Your application makes calls to COM components that use the multithreaded apartment model.

Konstruktoren

MTAThreadAttribute() MTAThreadAttribute() MTAThreadAttribute() MTAThreadAttribute()

Initialisiert eine neue Instanz der MTAThreadAttribute-Klasse.Initializes a new instance of the MTAThreadAttribute 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