在C語言中,三元數(shù)組(或稱為三維數(shù)組)的內(nèi)存分配需要明確數(shù)組的維度大小。以下是一個(gè)示例,展示了如何為一個(gè)三維數(shù)組分配內(nèi)存:
#include <stdio.h>
#include <stdlib.h>
int main() {
// 定義三維數(shù)組的大小
int x = 3, y = 4, z = 5;
// 為三維數(shù)組分配內(nèi)存
int ***array = (int ***)malloc(x * sizeof(int **));
if (array == NULL) {
printf("內(nèi)存分配失敗!\n");
return 1;
}
for (int i = 0; i < x; i++) {
array[i] = (int **)malloc(y * sizeof(int *));
if (array[i] == NULL) {
printf("內(nèi)存分配失??!\n");
return 1;
}
for (int j = 0; j < y; j++) {
array[i][j] = (int *)malloc(z * sizeof(int));
if (array[i][j] == NULL) {
printf("內(nèi)存分配失??!\n");
return 1;
}
}
}
// 使用數(shù)組...
// 釋放內(nèi)存
for (int i = 0; i < x; i++) {
for (int j = 0; j < y; j++) {
free(array[i][j]);
}
free(array[i]);
}
free(array);
return 0;
}
在這個(gè)示例中,我們首先定義了三維數(shù)組的大?。▁、y和z),然后使用malloc
函數(shù)為數(shù)組分配內(nèi)存。注意,我們首先為最外層的數(shù)組分配內(nèi)存,然后為其子數(shù)組分配內(nèi)存,最后為最內(nèi)層的數(shù)組分配內(nèi)存。在釋放內(nèi)存時(shí),我們需要按照相反的順序進(jìn)行,以確保正確地釋放所有分配的內(nèi)存。