C++编程之数组降阶问题

来源:互联网 发布:两小无猜网络剧百度云 编辑:程序博客网 时间:2024/06/07 02:41
 

数组的降价问题及解决办法???
什么是数组的降价问题呢?
看下面的程序,
void Test( char array[20] )
{
     cout << sizeof(array) << endl; // 输出 4
}

char array[20] = { 0 };
cout << sizeof(array) << endl; // 输出 20Test( array );

   我们看到,对于同样的数组array,一个输出4,另一个输出20. 这是因为void Test( char array[20] ) 中的array被降阶处理了,void Test( char array[20] ) 等同于 void Test( char array[] ) 也等同于void Test( char* const array ) 如果你原意,它甚至等同于void Test( char array[999] )。

   这样以来,我们在函数声明中的数组大小限制是无效的,声明 void Test( char array[20] ) 并不能保证一定会接收到一个大小20的数组,即任何 char[] 都会被降价为 char* ,这样就增加了程序出错的可能性。要解决这样一个问题,我们可以用C++的数组引用作为参数,看以下代码:

void Test( char (&array)[20] )//是不是很像 char *p[20] 和 char (*p)[20] 的区别?
{
     cout << sizeof(array) << endl;
}


char array[20] = { 0 };
cout << sizeof(array) << endl;
Test( array );
   在 C++ 中,单纯的用数组的引用可以直接传递数组名,因为它将数组的大小已在形参里提供了信息。

原创粉丝点击