SuppressUnmanagedCodeSecurityAttribute SuppressUnmanagedCodeSecurityAttribute SuppressUnmanagedCodeSecurityAttribute SuppressUnmanagedCodeSecurityAttribute Class

Definizione

Consente al codice gestito di effettuare chiamate nel codice non gestito senza percorso di stack.Allows managed code to call into unmanaged code without a stack walk. Questa classe non può essere ereditata.This class cannot be inherited.

public ref class SuppressUnmanagedCodeSecurityAttribute sealed : Attribute
[System.AttributeUsage(System.AttributeTargets.Class | System.AttributeTargets.Method | System.AttributeTargets.Interface | System.AttributeTargets.Delegate, AllowMultiple=true, Inherited=false)]
[System.Runtime.InteropServices.ComVisible(true)]
[System.AttributeUsage(System.AttributeTargets.Class | System.AttributeTargets.Delegate | System.AttributeTargets.Interface | System.AttributeTargets.Method, AllowMultiple=true, Inherited=false)]
[System.AttributeUsage(System.AttributeTargets.Class | System.AttributeTargets.Method | System.AttributeTargets.Interface, AllowMultiple=true, Inherited=false)]
public sealed class SuppressUnmanagedCodeSecurityAttribute : Attribute
type SuppressUnmanagedCodeSecurityAttribute = class
    inherit Attribute
Public NotInheritable Class SuppressUnmanagedCodeSecurityAttribute
Inherits Attribute
Ereditarietà
SuppressUnmanagedCodeSecurityAttributeSuppressUnmanagedCodeSecurityAttributeSuppressUnmanagedCodeSecurityAttributeSuppressUnmanagedCodeSecurityAttribute
Attributi

Commenti

Attenzione

Usare questo attributo con estrema attenzione.Use this attribute with extreme care. Uso non corretto può creare problemi di sicurezza.Incorrect use can create security weaknesses.

Questo attributo può essere applicato ai metodi che desidera chiamare codice nativo senza incorrere in questo caso la riduzione delle prestazioni di un controllo di sicurezza in fase di esecuzione.This attribute can be applied to methods that want to call into native code without incurring the performance loss of a run-time security check when doing so. Analisi dello stack eseguita quando si chiama codice non gestito viene omessa in fase di esecuzione conseguente notevole risparmio di risorse.The stack walk performed when calling unmanaged code is omitted at run time, resulting in substantial performance savings. Uso di questo attributo in una classe viene applicato a tutti i metodi indipendenti.Using this attribute in a class applies it to all contained methods.

In genere, ogni volta che il codice gestito chiama codice non gestito (tramite l'interoperabilità PInvoke o COM nel codice nativo), è disponibile una richiesta per il UnmanagedCode dell'autorizzazione per assicurarsi che tutti i chiamanti dispongano dell'autorizzazione necessaria per consentire questa operazione.Generally, whenever managed code calls into unmanaged code (by PInvoke or COM interop into native code), there is a demand for the UnmanagedCode permission to ensure all callers have the necessary permission to allow this. Applicando l'attributo esplicito, gli sviluppatori possono evitare la richiesta in fase di esecuzione.By applying this explicit attribute, developers can suppress the demand at run time. Lo sviluppatore deve assumersi la responsabilità per garantire che la transizione al codice non gestito è sufficientemente protetti da altri mezzi.The developer must take responsibility for assuring that the transition into unmanaged code is sufficiently protected by other means. La richiesta per il UnmanagedCode autorizzazione verrà comunque eseguita in fase di collegamento.The demand for the UnmanagedCode permission will still occur at link time. Ad esempio, se una funzione chiama la funzione B e la funzione B è contrassegnato con SuppressUnmanagedCodeSecurityAttribute, funzione verrà verificata per l'autorizzazione di codice durante la compilazione just-in-time, ma non successivamente durante la fase di esecuzione non gestito.For example, if function A calls function B and function B is marked with SuppressUnmanagedCodeSecurityAttribute, function A will be checked for unmanaged code permission during just-in-time compilation, but not subsequently during run time.

Questo attributo ha effetto solo quando applicato a metodi di PInvoke (o le classi che contengono metodi di PInvoke) o la definizione di un'interfaccia tramite cui verranno effettuate le chiamate di interoperabilità.This attribute is only effective when applied to PInvoke methods (or classes that contain PInvoke methods) or the definition of an interface through which interop calls will be made. Verrà ignorato in tutti gli altri contesti.It will be ignored in all other contexts.

Questo attributo è utile per implementare una classe che fornisce accesso alle risorse di sistema tramite codice non gestito.This attribute is useful for implementing a class that provides access to system resources through unmanaged code. Codice che non dispone dell'autorizzazione per accedere a codice non gestito può chiamare una classe con questo attributo per accedere al codice non gestito.Code that does not have permission to access unmanaged code can call a class with this attribute to access unmanaged code. Ciò è sicura solo se il writer della classe con questo attributo è programmato la classe sia sicuro.This is only safe if the writer of the class with this attribute has programmed the class to be secure. In caso contrario, questo attributo è un'operazione rischiosa e può consentire al codice che lo usa per un uso improprio.If not, this attribute is dangerous and can allow the code that uses it to be misused.

Ciò non è un attributo di sicurezza dichiarativa, ma un attributo normale (deriva da Attribute, non SecurityAttribute).This is not a declarative security attribute, but a regular attribute (it derives from Attribute, not SecurityAttribute).

Costruttori

SuppressUnmanagedCodeSecurityAttribute() SuppressUnmanagedCodeSecurityAttribute() SuppressUnmanagedCodeSecurityAttribute() SuppressUnmanagedCodeSecurityAttribute()

Inizializza una nuova istanza della classe SuppressUnmanagedCodeSecurityAttribute.Initializes a new instance of the SuppressUnmanagedCodeSecurityAttribute class.

Metodi

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

Restituisce un valore che indica se questa istanza è uguale a un oggetto specificato.Returns a value that indicates whether this instance is equal to a specified object.

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

Restituisce il codice hash per l'istanza.Returns the hash code for this instance.

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

Ottiene l'oggetto Type dell'istanza corrente.Gets the Type of the current instance.

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

In caso di override in una classe derivata, indica se il valore di questa istanza è il valore predefinito per la classe derivata.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)

Quando è sottoposto a override in una classe derivata, restituisce un valore che indica se questa istanza equivale a un oggetto specificato.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()

Crea una copia superficiale dell'oggetto Object corrente.Creates a shallow copy of the current Object.

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

Restituisce una stringa che rappresenta l'oggetto corrente.Returns a string that represents the current object.

(Inherited from Object)

Implementazioni dell'interfaccia esplicita

_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)

Esegue il mapping di un set di nomi a un set corrispondente di ID dispatch.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)

Recupera le informazioni sul tipo relative a un oggetto, che possono essere usate per ottenere informazioni sul tipo relative a un'interfaccia.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)

Recupera il numero delle interfacce di informazioni sul tipo fornite da un oggetto (0 o 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)

Fornisce l'accesso a proprietà e metodi esposti da un oggetto.Provides access to properties and methods exposed by an object.

(Inherited from Attribute)

Proprietà

TypeId TypeId TypeId TypeId

Quando è implementata in una classe derivata, ottiene un identificatore univoco della classe Attribute.When implemented in a derived class, gets a unique identifier for this Attribute.

(Inherited from Attribute)

Si applica a

Vedi anche