二維陣列動態分配記憶體

2021-09-10 09:53:20 字數 3041 閱讀 8769

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 ...