Exportar (0) Imprimir
Expandir todo
Expandir Minimizar
Este artículo proviene de un motor de traducción automática. Mueva el puntero sobre las frases del artículo para ver el texto original. Más información.
Traducción
Original
Este tema aún no ha recibido ninguna valoración - Valorar este tema

Extensiones de componentes para plataformas de tiempo de ejecución

Visual C++ proporciona extensiones de lenguaje para ayudarle a programar en plataformas del runtime. Mediante Extensiones de componentes de Visual C++ (C++/CX), puede programar aplicaciones y componentes de la Tienda Windows que se compilan en código nativo. Aunque puede crear aplicaciones de la Tienda Windows programando directamente en las interfaces COM de Windows en tiempo de ejecución mediante C++/CX, puede usar constructores, excepciones y otras expresiones de programación moderna de C++. Para habilitar la programación en C++ en un entorno de ejecución administrado en la plataforma .NET, puede usar C++/CLI.

Dos runtime, un conjunto de extensiones

C++/CX es un subconjunto de C++/CLI. Para las extensiones comunes a C++/CX y C++/CLI, la semántica depende de si el destino es Common Language Runtime (CLR) o Windows en tiempo de ejecución. Para compilar la aplicación para que se ejecute en Windows en tiempo de ejecución, especifique la opción del compilador /ZW. Para compilarlo para que se ejecute en CLR, especifique la opción del compilador /clr. Estos modificadores se establecen automáticamente cuando se usa Visual Studio para crear un proyecto.

Para obtener más información sobre cómo crear aplicaciones de la Tienda Windows en C++, vea Roadmap for Windows Store apps using C++.

C++/CLI extiende el estándar C++ de ANSI/ISO, y se define en la norma ECMA C++/CLI. Para obtener más información, vea Programación de .NET en Visual C++.

Las extensiones de lenguaje incluyen palabras clave agregadas, que son palabras clave que constan de dos tokens separados por espacios en blanco. Los tokens pueden tener un significado cuando se usan por separado, y otro significado cuando se usan juntos. Por ejemplo, la palabra “ref” es un identificador normal, y la palabra “clase” es una palabra clave que declara una clase nativa. Pero cuando estas palabras se combinan para formar ref class, la palabra clave agregada resultante declara una entidad denominada clase en tiempo de ejecución.

Las extensiones también incluyen palabras clave contextuales. Una palabra clave se trata como contextual en función del tipo de instrucción que la contenga, y de su posición en esa instrucción. Por ejemplo, el token “property” puede ser un identificador, o puede declarar una clase especial de miembro de clase pública.

En la tabla siguiente se enumeran las palabras clave en la extensión del lenguaje C++.

Palabra clave

Contextual

Propósito

Referencia

ref class

ref struct

No

Declara una clase.

Clases y structs (Extensiones de componentes de C++)

value class

value struct

No

Declara una clase de valor.

Clases y structs (Extensiones de componentes de C++)

interface class

interface struct

No

Declara una interfaz.

interface class (Extensiones de componentes de C++)

enum class

enum struct

No

Declara una enumeración.

enum class (Extensiones de componentes de C++)

property

Si

Declara una propiedad.

property (Extensiones de componentes de C++)

delegate

Si

Declara un delegado.

delegate (Extensiones de componentes de C++)

event

Si

Declara un evento.

event (Extensiones de componentes de C++)

Puede usar las palabras clave siguientes para calificar el comportamiento de invalidación de la derivación. Aunque la palabra clave new no es una extensión de C++, se muestra aquí porque se puede usar en un contexto adicional. Algunos especificadores también son válidos para la programación nativa. Para obtener más información, vea Cómo: Declare los especificadores de reemplazo en compila nativas.

Palabra clave

Contextual

Propósito

Referencia

abstract

Si

Indica que las funciones o las clases son abstractas.

abstract (Extensiones de componentes de C++)

new

No

Indica que una función no es una invalidación de una versión de la clase base.

new (nueva ranura en vtable) (Extensiones de componentes de C++)

override

Si

Indica que un método debe ser una invalidación de una versión de la clase base.

override (Extensiones de componentes de C++)

sealed

Si

Evita que las clases se usen como clases base.

sealed (Extensiones de componentes de C++)

Las palabras clave siguientes se han agregado para admitir tipos genéricos. Para obtener más información, vea Genéricos (Extensiones de componentes de C++).

Palabra clave

Contextual

Propósito

generic

No

Declara un tipo genérico.

where

Si

Especifica las restricciones que se aplican a un parámetro de tipo genérico.

Las palabras clave siguientes se han agregado a las extensiones de C++.

Palabra clave

Contextual

Propósito

Referencia

finally

Si

Indica el comportamiento predeterminado de los controles de excepciones.

Control de excepciones (Extensiones de componentes de C++)

for each, in

No

Enumera los elementos de una colección.

para cada, en

gcnew

No

Asigna tipos en el montón de recolección de elementos no utilizados. Úselo en lugar de new y delete.

ref new, gcnew (Extensiones de componentes de C++)

ref new

Si

Asigna un tipo Windows en tiempo de ejecución. Úselo en lugar de new y delete.

ref new, gcnew (Extensiones de componentes de C++)

initonly

Si

Indica que un miembro solo se puede inicializar en la declaración o en un constructor estático.

initonly

literal

Si

Crea una variable literal.

literal (Extensiones de componentes de C++)

nullptr

No

Indica que un identificador o un puntero no señala un objeto.

nullptr (Extensiones de componentes de C++)

Las construcciones de lenguaje siguientes se implementan como plantillas, en lugar de como palabras clave. Si especifica la opción del compilador /ZW, se definen en el espacio de nombres lang. Si especifica la opción del compilador /clr, se definen en el espacio de nombres cli.

Palabra clave

Propósito

Referencia

array

Declara una matriz.

Matrices (Extensiones de componentes de C++)

interior_ptr

(solo CLR) Apunta a los datos de un tipo de referencia.

interior_ptr (C++/CLI)

pin_ptr

(solo CLR) Apunta a los tipos de referencia CLR para suprimir temporalmente el sistema de recolección de elementos no utilizados.

pin_ptr (C++/CLI)

safe_cast

Determina y ejecuta el método óptimo de conversión para un tipo de runtime.

safe_cast (Extensiones de componentes de C++)

typeid

(solo CLR) Recupera un objeto System.Type que describe el tipo o el objeto especificado.

typeid (Extensiones de componentes de C++)

Los declaradores de tipo siguientes indican al runtime que debe administrar automáticamente la duración y eliminación de los objetos asignados.

operador

Propósito

Referencia

^

Declara un identificador a un objeto; es decir, un puntero a un objeto Windows en tiempo de ejecución o CLR que se elimina automáticamente cuando ya no se usa.

Operador de identificador de objeto (^) (Extensiones de componentes de C++)

%

Declara una referencia de seguimiento; es decir, una referencia a un objeto Windows en tiempo de ejecución o CLR que se elimina automáticamente cuando ya no se usa.

Operador de referencia de seguimiento (Extensiones de componentes de C++)

En esta sección se muestran construcciones de programación adicionales y temas que pertenecen a CLR.

Tema

Descripción

__identifier (C++/CLI)

(Windows en tiempo de ejecución y CLR) Habilita el uso de palabras clave como identificadores.

Listas de argumentos de variables (...) (C++/CLI)

(Windows en tiempo de ejecución y CLR) Permite que una función tome un número variable de argumentos.

Equivalentes de .NET Framework para tipos nativos de C++ (C++/CLI)

Enumera los tipos CLR que se usan en lugar de los tipos enteros de C++.

Modificador appdomain__declspec

El modificador __declspec que requiere la existencia de variables static y globales por appdomain.

Conversiones de estilo C con /clr (C++/CLI)

Describe cómo se interpretan las conversiones de tipo C.

Convención de llamada __clrcall

Indica la convención de llamada conforme a CLR.

__cplusplus_cli

Macros predefinidas

Atributos personalizados (C++)

Describe cómo definir sus propios atributos de CLR.

Control de excepciones (Extensiones de componentes de C++)

Proporciona información general sobre el control de excepciones.

Invalidaciones explícitas (Extensiones de componentes de C++)

Muestra cómo las funciones miembro pueden invalidar miembros arbitrarios.

Ensamblados de confianza (C++)

Explica cómo un ensamblado de cliente puede tener acceso a todos los tipos de un componente de ensamblado.

Conversión boxing (Extensiones de componentes de C++)

Muestra las condiciones en las que a los tipos de valores se les aplica la conversión boxing.

Compatibilidad de compilador para type traits (Extensiones de componentes de C++)

Explica cómo detectar características de tipos en tiempo de compilación.

Directivas pragma managed, unmanaged

Muestra cómo las funciones administradas y no administradas pueden coexistir en el mismo módulo.

Modificador proceso__declspec

El modificador __declspec que requiere la existencia de variables static y globales por proceso.

Reflexión (C++/CLI)

Muestra la versión de CLR de la información de tipo en tiempo de ejecución.

Cadena (Extensiones de componentes de C++)

Describe la conversión del compilador de literales de cadena a String.

Reenvío de tipos (C++/CLI)

Habilita el movimiento de un tipo en un ensamblado de envío a otro ensamblado de modo que no es necesario volver a compilar el código de cliente.

Atributos definidos por el usuario (Extensiones de componentes de C++)

Muestra atributos definidos por el usuario.

#using (Directiva) (C++)

Importa ensamblados externos.

Documentación XML (Visual C++)

Explica la documentación del código basado en XML mediante /doc (Procesar comentarios de documentación) (C/C++)

¿Te ha resultado útil?
(Caracteres restantes: 1500)
Gracias por sus comentarios

Adiciones de comunidad

AGREGAR
Mostrar:
© 2014 Microsoft. Reservados todos los derechos.