C++中数组名的二义性表现在在不同的上下文,数组名所代表的含义可能不一样,我们都知道数组名一般情况下表示数组首元素的地址,但是如下面的例子:
#include<iostream>
using namespace std;
void fun(int arr[3])
{
cout<<sizeof(arr)<<endl;
}
int main()
{
int arr[3]={0};
cout<<sizeof(arr)<<endl;
fun(arr);
return 0;
}
程序输出结果为:
12
4
这就是数组的二义性,同样执行sizeof(arr)却得到了不同的结果。
结论:
数组名直接作为sizeof的参数时,数组名代表整个数组;
数组名作为函数的参数传递给函数时,数组名代表首元素的地址
那如果我们就是需要函数的参数中传递整个数组怎么办,可能有的童鞋说那就传递一个数组指针,然后通过解引用获取整个数组?可不可行呢?看下面的例子:
#include<iostream>
using namespace std;
void fun(int(*arr)[3])
{
cout<<sizeof(*arr)<<endl;
}
int main()
{
int arr[3]={0};
cout<<sizeof(arr)<<endl;
fun(&arr);
return 0;
}
程序输出结果是:
12
12
说明可以通过数组的指针将整个数组作为实参传递过去。
还有一种方法就是使用数组的引用:
#include<iostream>
using namespace std;
void fun(int(&arr)[3])
{
cout<<sizeof(arr)<<endl;
}
int main()
{
int arr[3]={0};
cout<<sizeof(arr)<<endl;
fun(arr);
return 0;
}
程序输出结果是:
12
12
需要特别说明的是使用数组的指针或者引用时:
1、fun函数的实参一定要写成这种带数组元素个数的[3]的形式,而不能只用一个[]
2、注意区分int* arr[]和int (*arr)的区别,前者表示指针数组,后者表示数组的指针,可以这样来记忆:从左到右,如果遇见单独的int,*和数组名放在小括号里,说明数组中存放的是int,就是数组的指针;而先遇见的是int* ,说明数组中存放的是int*,就是指针的数组。