Partager via


Plan des modifications (C++/CLI)

Ce plan propose des exemples de quelques-unes des modifications du langage entre Extensions managées pour C++ et Visual C++. Suivez le lien qui accompagne chaque élément pour obtenir plus d'informations.

Aucun mot clé à trait de soulignement double

Le trait de soulignement double qui précède tous les mots clés a été supprimé, à une exception près. Donc, __value devient value et __interface devient interface, etc. Pour empêcher des conflits de nom entre des mots clés et des identificateurs dans le code utilisateur, les mots clés sont essentiellement traités comme contextuels.

Pour plus d'informations, consultez Mots clés de langage (C++/CLI).

Déclarations de classe

Syntaxe des Extensions managées :

__gc class Block {};                           // reference class
__value class Vector {};                       // value class
__interface I {};                        // interface class
__gc __abstract class Shape {};                // abstract class
__gc __sealed class Shape2D : public Shape {}; // derived class

Nouvelle syntaxe :

ref class Block {};                // reference class
value class Vector {};             // value class
interface class I {};        // interface class
ref class Shape abstract {};       // abstract class
ref class Shape2D sealed: Shape{}; // derived class

Pour plus d'informations, consultez Types managés (C++/CL).

Déclaration d'objet

Syntaxe des Extensions managées :

public __gc class Form1 : public System::Windows::Forms::Form {
private:
   System::ComponentModel::Container __gc *components;
   System::Windows::Forms::Button   __gc *button1;
   System::Windows::Forms::DataGrid __gc *myDataGrid;   
   System::Data::DataSet  __gc *myDataSet;
};

Nouvelle syntaxe :

public ref class Form1 : System::Windows::Forms::Form {
   System::ComponentModel::Container^ components;
   System::Windows::Forms::Button^ button1;
   System::Windows::Forms::DataGrid^ myDataGrid;
   System::Data::DataSet^ myDataSet;
};

Pour plus d'informations, consultez Déclaration d'un objet de classe de référence du CLR.

Allocation de tas géré

Syntaxe des Extensions managées :

Button* button1 = new Button; // managed heap
int *pi1 = new int;           // native heap
Int32 *pi2 = new Int32;       // managed heap

Nouvelle syntaxe :

Button^ button1 = gcnew Button;        // managed heap
int * pi1 = new int;                   // native heap
Int32^ pi2 = gcnew Int32;              // managed heap

Pour plus d'informations, consultez Déclaration d'un objet de classe de référence du CLR.

Une référence de suivi à aucun objet

Syntaxe des Extensions managées :

// OK: we set obj to refer to no object
Object * obj = 0;

// Error: no implicit boxing
Object * obj2 = 1;

Nouvelle syntaxe :

// Incorrect Translation
// causes the implicit boxing of both 0 and 1
Object ^ obj = 0;
Object ^ obj2 = 1;

// Correct Translation
// OK: we set obj to refer to no object
Object ^ obj = nullptr;

// OK: we initialize obj2 to an Int32^
Object ^ obj2 = 1;

Pour plus d'informations, consultez Déclaration d'un objet de classe de référence du CLR.

Déclaration de tableau

Le tableau CLR a été refondu. Il est similaire à la collection de modèles vector stl, mais correspond à la classe System::Array sous-jacente – autrement dit, il ne s'agit pas d'une implémentation de modèle.

Pour plus d'informations, consultez Déclaration d'un tableau CLR.

Tableau comme paramètre

Syntaxe de tableau des extensions managées :

void PrintValues( Object* myArr __gc[]); 
void PrintValues( int myArr __gc[,,]); 

Nouvelle syntaxe de tableau :

void PrintValues( array<Object^>^ myArr );
void PrintValues( array<int,3>^ myArr );

Tableau comme type de retour

Syntaxe de tableau des extensions managées :

Int32 f() []; 
int GetArray() __gc[];

Nouvelle syntaxe de tableau :

array<Int32>^ f();
array<int>^ GetArray();

Initialisation abrégée de tableau CLR local

Syntaxe de tableau des extensions managées :

int GetArray() __gc[] {
   int a1 __gc[] = { 1, 2, 3, 4, 5 };
   Object* myObjArray __gc[] = { __box(26), __box(27), __box(28),
                                 __box(29), __box(30) };

   return a1;
}

Nouvelle syntaxe de tableau :

array<int>^ GetArray() {
   array<int>^ a1 = {1,2,3,4,5};
   array<Object^>^ myObjArray = {26,27,28,29,30};

   return a1;
}

Déclaration de tableau CLR explicite

Syntaxe de tableau des extensions managées :

Object* myArray[] = new Object*[2];
String* myMat[,] = new String*[4,4];

Nouvelle syntaxe de tableau :

array<Object^>^ myArray = gcnew array<Object^>(2);
array<String^,2>^ myMat = gcnew array<String^,2>(4,4);

Nouveauté du langage : initialisation de tableau explicite à la suite de gcnew

// explicit initialization list follow gcnew 
// is not supported in Managed Extensions
array<Object^>^ myArray = 
   gcnew array<Object^>(4){ 1, 1, 2, 3 };

Propriétés scalaires

Syntaxe des propriétés en Extensions managées :

public __gc __sealed class Vector {
   double _x;

public:
   __property double get_x(){ return _x; }
   __property void set_x( double newx ){ _x = newx; }
};

Nouvelle syntaxe des propriétés :

public ref class Vector sealed { 
   double _x;

public:
   property double x 
   {
      double get()             { return _x; }
      void   set( double newx ){ _x = newx; }
   } // Note: no semi-colon …
};

Nouveauté du langage : propriétés triviales

public ref class Vector sealed { 
public:
   // equivalent shorthand property syntax
   // backing store is not accessible
   property double x; 
};

Pour plus d'informations, consultez Déclaration de propriété.

Propriétés indexées

Syntaxe des propriétés indexées en Extensions managées :

public __gc class Matrix {
   float mat[,];

public: 
   __property void set_Item( int r, int c, float value) { mat[r,c] = value; }
   __property int get_Item( int r, int c ) { return mat[r,c]; }
};

Nouvelle syntaxe des propriétés indexées :

public ref class Matrix {
   array<float, 2>^ mat;

public:
   property float Item [int,int] {
      float get( int r, int c ) { return mat[r,c]; }
      void set( int r, int c, float value ) { mat[r,c] = value; }
   }
};

Nouveauté du langage : propriété indexée de niveau de classe

public ref class Matrix {
   array<float, 2>^ mat;

public:
   // ok: class level indexer now
   //     Matrix mat;
   //     mat[ 0, 0 ] = 1; 
   //
   // invokes the set accessor of the default indexer

   property float default [int,int] {
      float get( int r, int c ) { return mat[r,c]; }
      void set( int r, int c, float value ) { mat[r,c] = value; }
   }
};

Pour plus d'informations, consultez Déclaration de l'index de la propriété.

Opérateurs surchargés

Syntaxe de la surcharge d'opérateur en Extensions managées :

public __gc __sealed class Vector {
public:
   Vector( double x, double y, double z );

   static bool    op_Equality( const Vector*, const Vector* );
   static Vector* op_Division( const Vector*, double );
};

int main() {
   Vector *pa = new Vector( 0.231, 2.4745, 0.023 );
   Vector *pb = new Vector( 1.475, 4.8916, -1.23 ); 

   Vector *pc = Vector::op_Division( pa, 4.8916 );

   if ( Vector::op_Equality( pa, pc ))
      ;
}

Nouvelle syntaxe de la surcharge d'opérateur :

public ref class Vector sealed {
public:
   Vector( double x, double y, double z );

   static bool    operator ==( const Vector^, const Vector^ );
   static Vector^ operator /( const Vector^, double );
};

int main() {
   Vector^ pa = gcnew Vector( 0.231, 2.4745, 0.023 );
   Vector^ pb = gcnew Vector( 1.475, 4.8916, -1.23 );

   Vector^ pc = pa / 4.8916;
   if ( pc == pa )
      ;
}

Pour plus d'informations, consultez Opérateurs surchargés.

Opérateurs de conversion

Syntaxe de l'opérateur de conversion en Extensions managées :

__gc struct MyDouble {
   static MyDouble* op_Implicit( int i ); 
   static int op_Explicit( MyDouble* val );
   static String* op_Explicit( MyDouble* val ); 
};

Nouvelle syntaxe de l'opérateur de conversion :

ref struct MyDouble {
public:
   static operator MyDouble^ ( int i );
   static explicit operator int ( MyDouble^ val );
   static explicit operator String^ ( MyDouble^ val );
};

Pour plus d'informations, consultez Modifications apportées aux opérateurs de conversion.

Substitution explicite d'un membre d'interface

Syntaxe de la substitution explicite en Extensions managées :

public __gc class R : public ICloneable {
   // to be used through ICloneable
   Object* ICloneable::Clone();

   // to be used through an R
   R* Clone();
};

Nouvelle syntaxe de la substitution explicite :

public ref class R : public ICloneable {
   // to be used through ICloneable
   virtual Object^ InterfaceClone() = ICloneable::Clone;

   // to be used through an R 
   virtual R^ Clone();
};

Pour plus d'informations, consultez Substitution explicite d'un membre d'interface.

Fonctions virtuelles privées

Syntaxe des fonctions virtuelles privées en Extensions managées :

__gc class Base {
private:
   // inaccessible to a derived class
   virtual void g(); 
};

__gc class Derived : public Base {
public:
   // ok: g() overrides Base::g()
   virtual void g();
};

Nouvelle syntaxe des fonctions virtuelles privées

ref class Base {
private:
   // inaccessible to a derived class
   virtual void g(); 
};

ref class Derived : public Base {
public:
   // error: cannot override: Base::g() is inaccessible
   virtual void g() override;
};

Pour plus d'informations, consultez Fonctions virtuelles privées.

Type Enum du CLR

Syntaxe des enums en Extensions managées :

__value enum e1 { fail, pass };
public __value enum e2 : unsigned short  { 
   not_ok = 1024, 
   maybe, ok = 2048 
};  

Nouvelle syntaxe des enums :

enum class e1 { fail, pass };
public enum class e2 : unsigned short { 
   not_ok = 1024,
   maybe, ok = 2048 
};

Outre cette légère modification syntaxique, le comportement du type d'enum du CLR a été modifié de plusieurs manières :

  • La déclaration anticipée d'un enum du CLR n'est plus prise en charge.

  • La résolution de la surcharge entre les types arithmétiques intégrés et la hiérarchie des classes Objet a été inversée entre Extensions managées et Visual C++. Un des effets secondaires est que les enums du CLR ne sont plus convertis implicitement en types arithmétiques.

  • Dans la nouvelle syntaxe, un enum du CLR conserve sa propre portée, ce qui n'est pas le cas en Extensions managées. Auparavant, les énumérateurs étaient visibles dans la portée contenant l'enum ; dorénavant, ils sont encapsulés dans la portée de l'enum.

Pour plus d'informations, consultez Type Enum du CLR.

Suppression du mot clé __box

Syntaxe de la conversion boxing en Extensions managées :

Object *o = __box( 1024 ); // explicit boxing

Nouvelle syntaxe de la conversion boxing :

Object ^o = 1024; // implicit boxing

Pour plus d'informations, consultez Handle de suivi d'une valeur boxed.

Pointeur épingle

Syntaxe du pointeur épingle en Extensions managées :

__gc struct H { int j; };

int main() {
   H * h = new H;
   int __pin * k = & h -> j;
};

Nouvelle syntaxe du pointeur épingle :

ref struct H { int j; };

int main() {
   H^ h = gcnew H;
   pin_ptr<int> k = &h->j;
}

Pour plus d'informations, consultez Sémantique de type valeur.

Le mot clé __typeof devient typeid

Syntaxe de typeof en Extensions managées :

Array* myIntArray = 
   Array::CreateInstance( __typeof(Int32), 5 );

Nouvelle syntaxe de typeid :

Array^ myIntArray = 
   Array::CreateInstance( Int32::typeid, 5 );

Pour plus d'informations, consultez typeof va à T::typeid.

Voir aussi

Concepts

Initiation à la migration de C++/CLI

Fonctionnalités de langage pour cibler le CLR

Autres ressources

Managed Extensions for C++ Syntax Upgrade Checklist