正文
爲將數組類型和元素數量告訴數組處理函數,請通過兩個不同的參數來傳遞他們:
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