传递数组到函数中

正文

为将数组类型和元素数量告诉数组处理函数,请通过两个不同的参数来传递他们:

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 
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<" =  array address, ";
    std::cout< cookies<<" = sizeof cookies\n";

    int sum = sum_arr(cookies, ArSize);
    std::cout<<"total cookies eaten: "<::endl;
    sum = sum_arr(cookies, 3);
    std::cout<<"first three eaters ate "<" cookies.\n";
    sum = sum_arr(cookies+4, 4);
    std::cout<<"last four eaters ate "<" cookies.\n";

    std::cout<<"\n\nreference:\n";
    int *a;
    int b;
    std::cout<<"int *a; sizeof a="< a<<"\n";
    std::cout<<"int  b; sizeof b="< b<<"\n";

    return 0;
}

int sum_arr(int arr[], int n)
{
    int total = 0;
    std::cout<" = arr, ";
    std::cout< arr<<" = sizeof arr\n";
    for(int i=0;ireturn 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

你可能感兴趣的:(C/C++)