正文
为将数组类型和元素数量告诉数组处理函数,请通过两个不同的参数来传递他们:
void fillArray(int arr[], int size); //原型
而不要试图使用方括号表示法来传递数组长度:
void fillArray(int arr[size]); //不正确
解释
在大多数情况下,C++和C语言一样,也将数组名视为指针。C++将数组名解释为其第一个元素的地址:
cookies == &cookies[0]
该规则有一些例外:
- 数组声明使用数组名来标记存储位置
- 对数组名使用sizeof将得到整个数组的长度(以字节为单位)
- 将地址运算符&用于数组名时,将返回整个数组的地址,例如&cookies将返回一个32字节内存块的地址(如果int长4字节)
看下边一个例子,
int sum=sum_arr(cookies, ArSize);
其中,cookies是数组名,根据C++规则,cookies是其第一个元素的地址,因此函数传递的是地址。由于数组的元素的类型是int,因此cookies的类型必须是int指针,即int *。这表明,正确的函数头应该是这样的:
int sum_arr(int *arr, int n);
其中用int *arr
替换了int arr[]
。这证明这两个函数头都是正确的,因为在C++中,当且仅当用于函数头或函数原型中,int *arr和int arr[]的含义才是相同的。它们都意味着arr是一个int指针。然而,数组表示法(int arr[])提醒用户,arr不仅指向int,还指向int数组的第一个int。
例子
这如下程序中,并没有将数组内容传递给函数,而是将数组的位置(地址)、包含的元素种类(类型)以及元素数目提交给函数。有了这些信息以后,函数便可以使用原来的数组。
传递常规变量时,函数将使用该变量的拷贝;但传递数组时,函数将使用原来的数组。实际上,这种区别并不违反C++按值传递的方法,sum_arr()函数仍然传递了一个值,这个值被赋给一个新变量,但这个值是一个地址,而不是数组的内容。
- sizeof cookies是整个数组的长度
- sizeof arr只是指针变量的长度
#include <iostream>
const int ArSize=8;
int sum_arr(int arr[], int n);
int main()
{
int cookies[ArSize] = {1,2,4,8,16,32,64,128};
std::cout<<cookies<<" = array address, ";
std::cout<<sizeof cookies<<" = sizeof cookies\n";
int sum = sum_arr(cookies, ArSize);
std::cout<<"total cookies eaten: "<<sum<<std::endl;
sum = sum_arr(cookies, 3);
std::cout<<"first three eaters ate "<<sum<<" cookies.\n";
sum = sum_arr(cookies+4, 4);
std::cout<<"last four eaters ate "<<sum<<" cookies.\n";
std::cout<<"\n\nreference:\n";
int *a;
int b;
std::cout<<"int *a; sizeof a="<<sizeof a<<"\n";
std::cout<<"int b; sizeof b="<<sizeof b<<"\n";
return 0;
}
int sum_arr(int arr[], int n)
{
int total = 0;
std::cout<<arr<<" = arr, ";
std::cout<<sizeof arr<<" = sizeof arr\n";
for(int i=0;i<n;i++)
{
total += arr[i];
}
return total;
}
输出结果
0x7ffcb809e290 = array address, 32 = sizeof cookies
0x7ffcb809e290 = arr, 8 = sizeof arr
total cookies eaten: 255
0x7ffcb809e290 = arr, 8 = sizeof arr
first three eaters ate 7 cookies.
0x7ffcb809e2a0 = arr, 8 = sizeof arr
last four eaters ate 240 cookies.
reference:
int *a; sizeof a=8
int b; sizeof b=4
参考
- C++ Primer Plus, 6th, 中文版,P213