标签:
源文 :https://msdn.microsoft.com/zh-cn/library/ms235298%28v=vs.100%29.aspx
此概要给出一些示例,说明 C++ 托管扩展与 Visual C++ 2010 语言的某些不同。 有关更多信息,请访问每个项附带的链接。
移除了所有关键字前面的双下划线,仅有一个例外。 这样,__value 变为 value,而 __interface 变为 interface 等等。 若要防止用户代码中关键字与标识符之间的冲突,请首先将关键字视为上下文。
有关更多信息,请参见语言关键字。
托管扩展语法:
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; };
新语法:
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; };
有关更多信息,请参见 CLR 引用类对象的声明。
托管扩展语法:
Button* button1 = new Button; // managed heap int *pi1 = new int; // native heap Int32 *pi2 = new Int32; // managed heap
新语法:
Button^ button1 = gcnew Button; // managed heap int * pi1 = new int; // native heap Int32^ pi2 = gcnew Int32; // managed heap
有关更多信息,请参见 CLR 引用类对象的声明。
托管扩展语法:
// OK: we set obj to refer to no object Object * obj = 0; // Error: no implicit boxing Object * obj2 = 1;
新语法:
// 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;
有关更多信息,请参见 CLR 引用类对象的声明。
CLR 数组经过了重新设计。 它类似于 stl vector 模板集合,但映射到基础 System::Array 类 — 也就是说,它不是模板实现。
有关更多信息,请参见 CLR 数组的声明。
托管扩展数组语法:
void PrintValues( Object* myArr __gc[]); void PrintValues( int myArr __gc[,,]);
新数组语法:
void PrintValues( array<Object^>^ myArr ); void PrintValues( array<int,3>^ myArr );
托管扩展数组语法:
Int32 f() []; int GetArray() __gc[];
新数组语法:
array<Int32>^ f(); array<int>^ GetArray();
托管扩展数组语法:
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; }
新数组语法:
array<int>^ GetArray() { array<int>^ a1 = {1,2,3,4,5}; array<Object^>^ myObjArray = {26,27,28,29,30}; return a1; }
托管扩展数组语法:
Object* myArray[] = new Object*[2]; String* myMat[,] = new String*[4,4];
新数组语法:
array<Object^>^ myArray = gcnew array<Object^>(2); array<String^,2>^ myMat = gcnew array<String^,2>(4,4);
语言的新功能:显式数组初始化遵循 gcnew
// explicit initialization list follow gcnew // is not supported in Managed Extensions array<Object^>^ myArray = gcnew array<Object^>(4){ 1, 1, 2, 3 };
托管扩展属性语法:
public __gc __sealed class Vector { double _x; public: __property double get_x(){ return _x; } __property void set_x( double newx ){ _x = newx; } };
新属性语法:
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 … };
语言的新功能:trivial 属性
public ref class Vector sealed { public: // equivalent shorthand property syntax // backing store is not accessible property double x; };
有关更多信息,请参见属性声明。
托管扩展索引属性语法:
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]; } };
新索引属性语法:
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; } } };
语言的新功能:类级索引属性
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; } } };
有关更多信息,请参见属性索引声明。
托管扩展运算符重载语法:
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 )) ; }
新运算符重载语法:
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 ) ; }
有关更多信息,请参见 重载运算符。
托管扩展转换运算符语法:
__gc struct MyDouble { static MyDouble* op_Implicit( int i ); static int op_Explicit( MyDouble* val ); static String* op_Explicit( MyDouble* val ); };
新转换运算符语法:
ref struct MyDouble { public: static operator MyDouble^ ( int i ); static explicit operator int ( MyDouble^ val ); static explicit operator String^ ( MyDouble^ val ); };
有关更多信息,请参见转换运算符的更改。
托管扩展显式重写语法:
public __gc class R : public ICloneable { // to be used through ICloneable Object* ICloneable::Clone(); // to be used through an R R* Clone(); };
新显式重写语法:
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(); };
有关更多信息,请参见接口成员的显式重写。
托管扩展私有虚函数语法:
__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(); };
新私有虚函数语法
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; };
有关更多信息,请参见私有虚函数。
托管扩展枚举语法:
__value enum e1 { fail, pass }; public __value enum e2 : unsigned short { not_ok = 1024, maybe, ok = 2048 };
新枚举语法:
enum class e1 { fail, pass }; public enum class e2 : unsigned short { not_ok = 1024, maybe, ok = 2048 };
除此语法的稍微更改外,CLR 枚举的行为在许多方面发生了更改:
不再支持 CLR 枚举的前向声明。
内置算术类型和对象类层次结构之间的重载决策在托管扩展和 Visual C++ 2010 之间是相反的。 它的副作用是 CLR 枚举不再隐式转换为算术类型。
在新的语法中,CLR 枚举保持其自身范围,而在托管扩展中则不是这样。 以前,枚举数在枚举的包含范围内可见;现在,枚举数被封装在枚举的范围内。
有关更多信息,请参见 CLR 枚举类型。
托管扩展装箱语法:
Object *o = __box( 1024 ); // explicit boxing
新装箱语法:
Object ^o = 1024; // implicit boxing
有关更多信息,请参见装箱值的跟踪句柄。
托管扩展钉住指针语法:
__gc struct H { int j; }; int main() { H * h = new H; int __pin * k = & h -> j; };
新的钉住指针语法:
ref struct H { int j; }; int main() { H^ h = gcnew H; pin_ptr<int> k = &h->j; }
有关更多信息,请参见值类型语义。
托管扩展 typeof 语法:
Array* myIntArray = Array::CreateInstance( __typeof(Int32), 5 );
新 typeid 语法:
Array^ myIntArray = Array::CreateInstance( Int32::typeid, 5 );
有关更多信息,请参见 typeof 转到 T::typeid。
标签:
原文地址:http://www.cnblogs.com/mazhenyu/p/4546433.html