為將數組類型和元素數量告訴數組處理函數,請通過兩個不同的參數來傳遞他們:
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 cookies0x7ffcb809e290 = arr, 8 = sizeof arrtotal cookies eaten: 2550x7ffcb809e290 = arr, 8 = sizeof arrfirst three eaters ate 7 cookies.0x7ffcb809e2a0 = arr, 8 = sizeof arrlast four eaters ate 240 cookies.reference:int *a; sizeof a=8int b; sizeof b=4新聞熱點
疑難解答