C++中用二維數組傳參時形參該怎樣寫 [轉]


二維數組的存儲方式是和一維數組沒什么區別,但是用二維數組做參數,它的形參該怎樣寫?要注意的是:函數中的形參其實就相當於一個聲明,並不產生內存分配,形參的目的就是要讓編譯器知道函數參數的數據類型。


正確的是:

void Func(int array[3][10]); 

void Func(int array[][10]);  可以省略第一維的大小,

錯誤的是:

void Func(int array[][]).這樣的用法只能在初始化時可以用;

這樣寫也是錯誤:

void Func(const int m,const int n,int array[m][n]);

或 void Func(int m,int n,int array[m][n]);

大家都知道數組的索引必須是個常量表達式,void Func(const int m,const int n,int array[m][n]);如果const int m沒有初始化,那么系統將m或n自動初始化為0,所以這樣些是不對的.

 

如果我們采用這樣:

void Func(int **array, int m, int n) ,

那么在實際的函數調用是,我們就要進行強制轉換才可以用,我們可以這樣調用void Func((int **)array, int m, int n);在函數調用時,要把數組形式寫成指針形式如*((int*)array + n*i + j);直接寫int array[i][j]會導致錯誤,編譯可以通過,在VC編譯器中執行會出現異常,DEV編譯器會出現一個隨機值,原因就在於如果寫成int array[i][j],編譯器無法正確的尋址,當然各種編譯器對它的處理結果是不一樣的。如果我們的形參是數組,那么我們在函數體中可以用指針也可以用 數組形式,但是如果我們形參數中用的是指針,最好也用指針,有時用數組形式會出錯,二維數組就是這樣。

  

[轉] http://www.cppblog.com/zhangyq/archive/2008/12/29/70700.aspx


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2026 CODEPRJ.COM