1、数组将阶
#include <iostream>
using namespace std;
void test( char arr[100] )
{
cout << sizeof(arr) <<endl ; // 输出 4
}
int main()
{
char arr[100] = { 0 };
cout << sizeof(arr) <<endl; // 输出 100
test( arr );
return 0 ;
对于同样的arr,一个输出100,另一个输出4。是因为void test( char arr[100] )中的arr被降阶了。
void test( char arr[100] ) 等同于void test( char arr[] ),
也等同于void test( char* const arr )
它甚至等同于void test( char arr[10] )
编译器对数组的维数不作检查。 也就是说 void test( char arr[100] ) { cout << sizeof(arr) << endl; }
被降成 void test( char* const arr ) { cout << sizeof(arr) <<endl; // 既然是char*,当然输出4 }
这样,即然不检查数组的大小,对于需要保证数组大小的程序就会带来问题。如何解决这个问题呢?可以用c++中的对数组的引用。
#include <iostream>
using namespace std;
void test( char arr[100] )
{
cout << sizeof(arr) <<endl ; // 输出 4
}
void test1( const char (&arr)[100] )//这样test1就能接受100个char的数组,且只能接受大小为100的char数组
{
cout << sizeof(arr) <<endl ; // 输出 100
}
int main()
{
char arr[100] = { 0 };
cout << sizeof(arr) <<endl; // 输出 100
test( arr );
test1(arr);
/*char arr[20] = {0};
test1( arr ) ;*///会出错!!!
return 0 ;
}