C++給函數傳數組參數
在C++中,如果要給一個函數傳入一個數組,一般都是傳入兩個參數一個數組指針和一個數組大小
例:
void print_1 (int n, int *datas?)
{
??? for (int i = 0; i < n; ++i)
??? {
??????? std::cout << datas[i] << " ";
??? }
??? std::cout << std::endl;
}
對這個函數,我們可以這樣使用它:
const int N = 3;
int datas[N] = {1, 2, 3};
print_1 (N, datas);
不過對這個函數,我們可能會傳錯 n 的大小,而在運行時可能出錯,例如這樣使用:
const int N = 3;
int datas[N] = {1, 2, 3};
print_1 (4?, datas);
有些時候,我們希望某函數只接受指定大小的數組,例如我們希望只接受大小為 3 的數組:
void print_2 (int datas[3]?)
{
??? for (int i = 0; i <?3?; ++i)
??? {
??????? std::cout << datas[i] << " ";
??? }
??? std::cout << std::endl;
}
但實際上,上面的函數不能正確工作:
const int N = 3;
int datas[N] = {1, 2, 3};
print_2 (datas);
int datas2[N - 1] = {1, 2};
print_2 (datas2);?
也就是我們傳入了一個大小為 2 的數組,編譯器沒報任何錯誤,我們的函數接口 print_2 (int datas[3?]) 中的 3 沒起任何作用
事實上,上面的函數接口應該這樣寫:
void print_3 (int?(&datas)?[3])
{
??? for (int i = 0; i < 3; ++i)
??? {
??????? std::cout << datas[i] << " ";
??? }
??? std::cout << std::endl;
}
這時,我們如果這樣使用是正確的
const int N = 3;
int datas[N] = {1, 2, 3};
print_3 (datas);
而我們如果這樣使用,編譯器會報錯
int datas2[N - 1] = {1, 2};
print_3 (datas2);
在上面這個例子(print_3)的基礎上,我們可以使用模板進行泛型實現
template<int N>
void print_4 (int (&datas)[N])?
{
??? for (int i = 0; i < N; ++i)
??? {
??????? std::cout << datas[i] << " ";
??? }
??? std::cout << std::endl;
}
這時候,我們可以傳遞任意大小數組,而不擔心給函數傳入了錯誤的參數
const int N = 3;
int datas[N] = {1, 2, 3};
print_4 (datas);
int datas2[N - 1] = {1, 2};
print_4 (datas2);
假如我們給傳了錯誤參數,函數將會報錯
const int N = 3;
int datas[N] = {1, 2, 3};
print_4<4?> (datas);
C++中二位數組作為函數參數
變量在作用域里面被聲明的是什么類型,就當作什么類型來用。
(1)參數是二維數組,但是要指定第二維的維數。
int array[10][10];
函數聲明:void fuc(int a[][10]);
函數調用:fuc(array);
——在函數fuc中,a是二維數組。使用a[i][j]形式來訪問數組中元素。
(2)參數使用一維指針數組。
int *array[10];
for(i = 0; i < 10; i++)
??? array[i] = new int[10];
函數聲明:void fuc(int *a[10]);
函數調用:fuc(array);
——在函數fuc中,a是一維指針數組。使用*(a[i] + j)形式來訪問數組中元素。
(3)參數使用指針的指針。
int **array;
array = new int *[10];
for(i = 0; i <10; i++)
??? array[i] = new int[10];
函數聲明:void fuc(int **a);
函數調用:fuc(array);
——在函數fuc中, a是指針的指針。使用*(int *)(a + i*d2 + j)形式來訪問數組中元素。其中:
a[0]<=>array[0][0],
a[1]<=>array[0][1],
…
a[10]<=>array[1][0]
注:d2為二維數組的二維維數,即列數。并且a + i*d2 + j為地址,所以要把這個類型為指針的指針的地址強制轉換為指針來使用
轉載自:http://blog.csdn.net/hongjiqin/article/details/5739935?
http://www.cnblogs.com/growup/archive/2011/03/01/1971529.html