如果您要使用malloc()
,則聲明innerStruct
爲inner *
,而不是struct inner
。
正如您聲明的那樣,創建outer
時分配了inner
的內存。
還請注意,由於您已使用typedef
,因此在聲明該類型的變量時,不需要struct
關鍵字。
這是你的代碼的修正版本,編譯和運行:
#include <stdio.h>
#include <stdlib.h>
typedef struct {
char address[32]; // 32 chars are allocated when an inner is created
} inner;
typedef struct {
inner innerStruct; // innerStruct is allocated when an outer is created
} outer;
typedef struct {
inner *innerStruct; // innerStruct must be allocated explicitly
} outer2;
int main(int argc, char *argv[]) {
int i = 0;
outer *outerArray;
outer2 *outer2Array;
outer *outerReference;
outer2 *outer2Reference;
/* create 20 outer structs (should check for out-of-mem error) */
outerArray = malloc(20 * sizeof(outer));
for (i = 0; i < 10; ++i) {
outerReference = outerArray + i; // ptr to i'th outer
// Note: innerStruct.address bcz it's a structure
sprintf(outerReference->innerStruct.address, "outer struct %d", i);
}
/* create 20 outer2 structs */
outer2Array = malloc(20 * sizeof(outer2));
/* for each outer struct, dynamically allocate 10 inner structs */
for (i = 0; i < 10; ++i) {
outer2Reference = outer2Array + i;
outer2Reference->innerStruct = malloc(sizeof(inner));
// Note: innerStruct->address bcz it's a pointer
sprintf(outer2Reference->innerStruct->address, "outer2 struct %d", i);
}
/* print all the data and free malloc'ed memory */
for (i = 0; i < 10; ++i) {
printf("outer: %-20s, outer2: %-20s\n",
outerArray[i].innerStruct.address,
outer2Array[i].innerStruct->address);
free(outer2Array[i].innerStruct);
}
free(outer2Array);
free(outerArray);
return 0;
}
該代碼無法編譯(出於多種原因)。除了別的之外,你似乎正在將指針與對象實例混同起來。 –
爲什麼downvote?這似乎是某人學習探究結構,指針和內存分配錯綜複雜的一個完全合法的問題。 –