c 二維陣列動態分配和釋放
(1)已知第二維
code-1
char (*a)[n];//指向陣列的指標
a = (char (*)[n])malloc(sizeof(char *) * m);
printf("%d\n", sizeof(a));//4,指標
printf("%d\n", sizeof(a[0]));//n,一維陣列
free(a);
(2)已知第一維
code-2
char* a[m];//指標的陣列
int i;
for(i=0; i
a[i] = (char *)malloc(sizeof(char) * n);
printf("%d\n", sizeof(a));//4*m,指標陣列
printf("%d\n", sizeof(a[0]));//4,指標
for(i=0; i
free(a[i]);
(3)已知第一維,一次分配記憶體(保證記憶體的連續性)
code-3
char* a[m];//指標的陣列
int i;
a[0] = (char *)malloc(sizeof(char) * m * n);
for(i=1; i
a[i] = a[i-1] + n;
printf("%d\n", sizeof(a));//4*m,指標陣列
printf("%d\n", sizeof(a[0]));//4,指標
free(a[0]);
(4)兩維都未知
code-4
char **a;
int i;
a = (char **)malloc(sizeof(char *) * m);//分配指標陣列
for(i=0; i
printf("%d\n", sizeof(a));//4,指標
printf("%d\n", sizeof(a[0]));//4,指標
for(i=0; i
free(a);
(5)兩維都未知,一次分配記憶體(保證記憶體的連續性)
code-5
char **a;
int i;
a = (char **)malloc(sizeof(char *) * m);//分配指標陣列
a[0] = (char *)malloc(sizeof(char) * m * n);//一次性分配所有空間
for(i=1; i
printf("%d\n", sizeof(a));//4,指標
printf("%d\n", sizeof(a[0]));//4,指標
free(a[0]);
free(a);
2.c++動態分配二維陣列
(1)已知第二維
code-6
char (*a)[n];//指向陣列的指標
a = new char[m][n];
printf("%d\n", sizeof(a));//4,指標
printf("%d\n", sizeof(a[0]));//n,一維陣列
delete a;
(2)已知第一維
code-7
char* a[m];//指標的陣列
for(int i=0; i
a[i] = new char[n];
printf("%d\n", sizeof(a));//4*m,指標陣列
printf("%d\n", sizeof(a[0]));//4,指標
for(i=0; i
delete a[i];
(3)已知第一維,一次分配記憶體(保證記憶體的連續性)
code-8
char* a[m];//指標的陣列
a[0] = new char[m*n];
for(int i=1; i
a[i] = a[i-1] + n;
printf("%d\n", sizeof(a));//4*m,指標陣列
printf("%d\n", sizeof(a[0]));//4,指標
delete a[0];
(4)兩維都未知
code-9
char **a;
a = new char* [m];//分配指標陣列
for(int i=0; i
printf("%d\n", sizeof(a));//4,指標
printf("%d\n", sizeof(a[0]));//4,指標
for(i=0; i
delete a[i];
delete a;
(5)兩維都未知,一次分配記憶體(保證記憶體的連續性)
code-10
char **a;
a = new char* [m];
a[0] = new char[m * n];//一次性分配所有空間
for(int i=1; i
printf("%d\n", sizeof(a));//4,指標
printf("%d\n", sizeof(a[0]));//4,指標
delete a[0];
delete a;
多說一句:new和delete要注意配對使用,即有多少個new就有多少個delete,這樣才可以避免記憶體洩漏!
3.靜態二維陣列作為函式引數傳遞
如果採用上述幾種方法動態分配二維陣列,那麼將對應的資料型別作為函式引數就可以了。這裡討論靜態二維陣列作為函式引數傳遞,即按照以下的呼叫方式:
int a[2][3];
func(a);
c語言中將靜態二維陣列作為引數傳遞比較麻煩,一般需要指明第二維的長度,如果不給定第二維長度,則只能先將其作為一維指標傳遞,然後利用二維陣列的線性儲存特性,在函式體內轉化為對指定元素的訪問。
首先寫好測試**,以驗證引數傳遞的正確性:
(1)給定第二維長度
code-11
void func(int a[n])
(2)不給定第二維長度
code-12
void func(int* a)
二維陣列動態分配記憶體
在robert sedgewick所著的algorithm in c中,把二維陣列當成陣列的陣列為它動態分配記憶體。首先,分配乙個指標的陣列,然後為每一行分配記憶體。函式定義 void malloc2d int r,int c,int size void free2d void arr,int r ...
二維陣列動態分配記憶體
對二維陣列分配動態空間 1.已知二維陣列的行 第一維 include include 已知陣列的行數 列數由終端輸入 int main void int i,j,num int a 3 已知陣列有3行 printf 請輸入二位陣列的列數 n scanf d num 列數由終端輸入 for i 0 i...
動態分配二維陣列
1.c語言動態分配二維陣列 1 已知第二維 code 1 char a n 指向陣列的指標 a char n malloc sizeof char m printf d n sizeof a 4,指標 printf d n sizeof a 0 n,一維陣列 free a 2 已知第一維 code ...