來看《c++ primer》中給出的方法:
[cpp]view plain
copy
void
func1(
intiarray[10])
intmain()
編譯通過,注意形參宣告一定要給出第二個維度的大小,要不編譯不過。
[cpp]view plain
copy
void
func2(
int(*parray)[10])
void
func2_1(
int(*parray))
//編譯通過,無法呼叫
intmain()
其實二維陣列名就是乙個指向一維陣列的指標,所以這種宣告方式ok。必須指定一維陣列的長度,如果沒有指定的話,函式宣告編譯通過。但是如果一旦有呼叫**,就有編譯不通過,因為沒有實參型別能匹配int.
[cpp]view plain
copy
void
func3(
int(&parray)[10][10])
intmain()
必須指定兩個維度的長度。
[cpp]view plain
copy
void
func4(
int(*parray)[10][10])
intmain()
必須指定兩個維度的長度。
以上方法都可以等價使用,對陣列來說,沒有值傳遞。
還不滿足,還有其他的宣告方式嗎?回到本文開始提到的問題:可以用雙重指標int**作為形參,接受二維陣列實參嗎?答案是肯定的,但是又侷限性。用雙重指標作為形參,那麼相應的實參也要是乙個雙重指標。事實上,這個雙重指標其實指向乙個元素是指標的陣列,雙重指標的宣告方式,很適合傳遞動態建立的二維陣列。怎麼動態建立乙個二維陣列?如下程式:
[cpp]view plain
copy
intmain()
會發現編譯不通過,第二個維度長度必須為常量。那麼怎麼宣告乙個兩個維度都能動態指定的二維陣列呢?看下面:
[cpp]view plain
copy
void
func5(
int** parray,
intm,
intn)
#include
intmain()
func5(parray, m, n);
}
這裡為二維陣列申請了一段連續的記憶體,然後給每乙個元素指定定址方式(也可以為每乙個元素分別申請記憶體,就不必指定定址方式了),最後將雙重指標作為實參傳遞給func5。這裡func5多了兩個形參,是二維陣列的維度,也可以不宣告這兩個形參,但是為了安全嘛,還是指定的好。最後編譯,執行,一切ok。總結一下,上面的**其實是實現了引數傳遞動態建立的二維陣列。
本文** [ ]
引數傳遞二維陣列
cpp view plain copy void func1 intiarray 10 intmain 編譯通過,注意形參宣告一定要給出第二個維度的大小,要不編譯不過。cpp view plain copy void func2 int parray 10 void func2 1 int parr...
引數傳遞二維陣列
來看 c primer 中給出的方法 void func1 int iarray 10 int main 編譯通過,注意形參宣告一定要給出第二個維度的大小,要不編譯不過。void func2 int parray 10 void func2 1 int parray 編譯通過,無法呼叫 int ma...
二維陣列的引數傳遞
二維陣列的引數傳遞 一 通過指標傳遞 前幾天在看演算法導論的時候遇到了乙個函式需要傳遞乙個二維陣列,例如 void function int a 或許你會和我一樣,這樣定義個乙個陣列,int a 2 2 然後呼叫函式,但結果如何呢?首先是呼叫的 includeusing namespace std ...