C++/CLI支持真正的多维数组
CLI数组的第二个参数为可选,其代表了一个数组的序(也即是数组的维数),默认为1。比如在前一个例子中,array<int>也能写成array<int,1>。(与模板的非类型参数相似,其必须为一个编译时的常量。)
例5:
int main() { /*1*/ array<String^, 2>^ names = gcnew array<String^, 2> (2,3) { {"John", "Robert", "Peter"}, {"Mary", "Alice"} }; /*2*/ Console::WriteLine("names has {0} elements", names->Length); /*3*/ Console::WriteLine("names has {0} dimensions", names->Rank); /*4*/ Console::WriteLine("names[0,0] is {0}", names[0,0]); /*5*/ names = gcnew array<String^, 2> (5,7); /*6*/ Console::WriteLine("names has {0} elements", names->Length); } | 请看例5,在标号1中,定义了一个指向String句柄的两维数组的句柄,但并未指明行数或列数,接下来,分配了一个2×3数组的内存空间,并以5个字符串及一个nullptr初始化了这6个数组元素,以下是输出:
names has 6 elements names has 2 dimensions names[0,0] is John names has 35 elements | Length属性给出了元素总数,而Rank属性给出了维数。
请注意标号4,可在一对中括号使用逗号分隔的索引数,用以访问多维数组的一个元素,在此,逗号为一个标点符号,而不是一个操作符。
也可把例中的names引用至任意的String^两维数组,比如在标号5中,把它重新引用至一个元素值全部为nullptr的5×7数组。
参数数组
请看下列代码的重载:
static String^ Concat(... array<Object^>^ list); | 左边圆括号后面声明的参数(必须有一个CLI数组类型),表明了其可接受一个数目可变的既定元素类型的参数。
例6演示了一个可接受多个Point句柄当作参数的函数,其返回最左边(即最小)的X坐标。(当然,这个函数也能是Point类的一个静态成员函数。)
例6:
int LeftMostX(... array<Point^>^ points);
int main() { /*1*/ array<Point^>^ p = gcnew array<Point^> { gcnew Point(10,3), gcnew Point(5,20), gcnew Point(-3, 4), gcnew Point(1,30), gcnew Point(-5,2) }; /*2*/ Console::WriteLine("LeftMostX is {0}", LeftMostX(p[1], p[3], p[0])); /*3*/ Console::WriteLine("LeftMostX is {0}", LeftMostX(p)); } int LeftMostX(... array<Point^>^ points) { /*4*/ int leftMostX = Int32::MaxValue; for each (Point^ p in points) { if (p->X < leftMostX) { leftMostX = p->X; } } return leftMostX; } | 在标号2中,调用了LeftMostX,并传递给它3个Point句柄,然而,在幕后,这个函数实际上只接受一个参数--一个指向Point句柄数组的句柄,同样地,编译器安排了这3个Point句柄传递进一个数组,并把数组的句柄传给函数。但也能像标号3那样,直接传递一个Point数组的句柄。
LeftMostX定义中,唯一新的东西是标号4,因为每种C++基本类型都会映射为一个相应定义实现在CLI库中的类型,例如,在Microsoft的实现中,short映射为System:Int16,int映射为System::Int32,而long long则映射为System:Int64;这些类型均为值类型,它们的实例被分配在堆栈上,而不是垃圾回收堆上。
MaxValue是类型Int32中一个公共静态字段,其值为2,147,483,647,它是有符号32位补码整数的最大值。(严格来说,MaxValue只是一个字面上的名称。)
[上一页] [1] [2] [3]
|