Compartir vía


RuntimeCompatibilityAttribute Clase

Definición

Especifica si las excepciones que no derivan de la clase Exception se ajustan con un objeto RuntimeWrappedException. Esta clase no puede heredarse.

public ref class RuntimeCompatibilityAttribute sealed : Attribute
[System.AttributeUsage(System.AttributeTargets.Assembly, AllowMultiple=false, Inherited=false)]
public sealed class RuntimeCompatibilityAttribute : Attribute
[System.AttributeUsage(System.AttributeTargets.Assembly, AllowMultiple=false, Inherited=false)]
[System.Serializable]
public sealed class RuntimeCompatibilityAttribute : Attribute
[<System.AttributeUsage(System.AttributeTargets.Assembly, AllowMultiple=false, Inherited=false)>]
type RuntimeCompatibilityAttribute = class
    inherit Attribute
[<System.AttributeUsage(System.AttributeTargets.Assembly, AllowMultiple=false, Inherited=false)>]
[<System.Serializable>]
type RuntimeCompatibilityAttribute = class
    inherit Attribute
Public NotInheritable Class RuntimeCompatibilityAttribute
Inherits Attribute
Herencia
RuntimeCompatibilityAttribute
Atributos

Ejemplos

En el ejemplo de código siguiente se muestra cómo aplicar la RuntimeCompatibilityAttribute clase a un ensamblado que produce un String objeto como una excepción en C++ y lo detecta mediante un RuntimeWrappedException objeto .

using namespace System;
using namespace System::Runtime::CompilerServices;

[assembly:RuntimeCompatibilityAttribute(WrapNonExceptionThrows = true)]; 

void run()
{
    try
    {
        throw gcnew String("This is a string");

    }
    catch(RuntimeWrappedException^ e)
    {
        Console::WriteLine("RuntimeWrappedException caught!");
    }
}

int main()
{
    run();

    return 0;
}

Comentarios

Algunos lenguajes, como C++, permiten producir excepciones de cualquier tipo. Otros lenguajes, como Microsoft C# y Visual Basic, requieren que todas las excepciones producidas se deriven de la Exception clase . Para mantener la compatibilidad entre lenguajes, Common Language Runtime (CLR) encapsula los objetos que no derivan de Exception en un RuntimeWrappedException objeto .

Puede usar la RuntimeCompatibilityAttribute clase para especificar si las excepciones deben aparecer encapsuladas dentro de bloques catch y filtros de excepción para un ensamblado. Muchos compiladores de lenguaje, incluidos los compiladores de Microsoft C# y Visual Basic, aplican este atributo de forma predeterminada para especificar el comportamiento de ajuste.

Tenga en cuenta que el tiempo de ejecución sigue ajustando las excepciones incluso si usa la RuntimeCompatibilityAttribute clase para especificar que no desea que se ajusten. En este caso, las excepciones solo se desencapsulan dentro de los bloques catch o los filtros de excepción.

Constructores

RuntimeCompatibilityAttribute()

Inicializa una nueva instancia de la clase RuntimeCompatibilityAttribute.

Propiedades

TypeId

Cuando se implementa en una clase derivada, obtiene un identificador único para este Attribute.

(Heredado de Attribute)
WrapNonExceptionThrows

Obtiene o establece un valor que indica si se deben ajustar las excepciones que no deriven de la clase Exception con un objeto RuntimeWrappedException.

Métodos

Equals(Object)

Devuelve un valor que indica si esta instancia es igual que un objeto especificado.

(Heredado de Attribute)
GetHashCode()

Devuelve el código hash de esta instancia.

(Heredado de Attribute)
GetType()

Obtiene el Type de la instancia actual.

(Heredado de Object)
IsDefaultAttribute()

Si se reemplaza en una clase derivada, indica si el valor de esta instancia es el valor predeterminado de la clase derivada.

(Heredado de Attribute)
Match(Object)

Cuando se invalida en una clase derivada, devuelve un valor que indica si esta instancia es igual a un objeto especificado.

(Heredado de Attribute)
MemberwiseClone()

Crea una copia superficial del Object actual.

(Heredado de Object)
ToString()

Devuelve una cadena que representa el objeto actual.

(Heredado de Object)

Implementaciones de interfaz explícitas

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

Asigna un conjunto de nombres a un conjunto correspondiente de identificadores de envío.

(Heredado de Attribute)
_Attribute.GetTypeInfo(UInt32, UInt32, IntPtr)

Obtiene la información de tipos de un objeto, que puede utilizarse para obtener la información de tipos de una interfaz.

(Heredado de Attribute)
_Attribute.GetTypeInfoCount(UInt32)

Recupera el número de interfaces de información de tipo que proporciona un objeto (0 ó 1).

(Heredado de Attribute)
_Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr)

Proporciona acceso a las propiedades y los métodos expuestos por un objeto.

(Heredado de Attribute)

Se aplica a