C++二維數(shù)組new幾種應(yīng)用方法點(diǎn)評
C++編程語言中有一種叫做new的二維數(shù)組,它的應(yīng)用方式比較靈活,可以有多種方法來幫助我們實(shí)現(xiàn)一些特定功能。在這里我們將會總結(jié)幾種C++二維數(shù)組new的應(yīng)用方式,來進(jìn)行逐一的點(diǎn)評。
C++二維數(shù)組new應(yīng)用方式一:
- A (*ga)[n] = new A[m][n];
- ...
- delete []ga;
缺點(diǎn):n必須是已知
優(yōu)點(diǎn):調(diào)用直觀,連續(xù)儲存,程序簡潔(經(jīng)過測試,析構(gòu)函數(shù)能正確調(diào)用)
C++二維數(shù)組new應(yīng)用方式二:
- A** ga = new A*[m];
- for(int i = 0; i < m; i++)
- ga[i] = new A[n];
- ...
- for(int i = 0; i < m; i++)
- delete []ga[i];
- delete []ga;
缺點(diǎn):非連續(xù)儲存,程序煩瑣,ga為A**類型
優(yōu)點(diǎn):調(diào)用直觀,n可以不是已知
C++二維數(shù)組new應(yīng)用方式三:
- A* ga = new A[m*n];
- ...
- delete []ga;
缺點(diǎn):調(diào)用不夠直觀
優(yōu)點(diǎn):連續(xù)儲存,n可以不是已知
C++二維數(shù)組new應(yīng)用方式四:
- vector > ga;
- ga.resize(m); //這三行可用可不用
- for(int i = 1; i < n; i++) //
- ga[i].resize(n); //
- ...
缺點(diǎn):非連續(xù)儲存,調(diào)試不夠方便,編譯速度下降,程序膨脹(實(shí)際速度差別不大)
優(yōu)點(diǎn):調(diào)用直觀,自動析構(gòu)與釋放內(nèi)存,可以調(diào)用stl相關(guān)函數(shù),動態(tài)增長
C++二維數(shù)組new應(yīng)用方式五:
- vector ga;
- ga.resize(m*n);
方法3,4的結(jié)合
C++二維數(shù)組new應(yīng)用方式六:
2的改進(jìn)版
- A** ga = new A*[m];
- ga[0] = new A[m*n];
- for(int i = 1; i < m; i++)
- ga[i] = ga[i-1]+n;
優(yōu)點(diǎn):連續(xù)存儲,n可以不是已知,析構(gòu)方便,猜想只需delete [] ga;
【編輯推薦】