如何正确地将包含 int 数组的结构分配给结构数组?
How do I correctly assign a struct containing an array of int to an array of struct?
我想知道如何将包含 int 数组的结构分配给结构数组。无论我想到什么新的解决方案,我总是得到不正确的结果。
我认为问题出在这段代码中:
struct Codes *create(int as) {
struct Codes *c = malloc(sizeof (struct Codes)+as * sizeof (int));
c->as = as;
for (int i = 0; i < as; i++) {
c->a[i] = i;
}
return c;
}
全部代码:
#include <stdio.h>
#include <stdlib.h>
#include <ctype.h>
struct Codes {
int as;
int a[];
};
struct Code {
int as;
struct Codes *ci[];
};
struct Codes *create(int as) {
struct Codes *c = malloc(sizeof (struct Codes)+as * sizeof (int));
c->as = as;
for (int i = 0; i < as; i++) {
c->a[i] = i;
}
return c;
}
struct Code *and(int as, struct Codes *cd) {
struct Code *c = malloc(sizeof (struct Code)+as * sizeof (struct Codes));
for (int i = 0; i < as; i++) {
c->ci[i] = cd;
}
c->as = as;
return c;
}
int main(int argc, char **argv) {
struct Codes *cd;
cd = create(4);
struct Code *c;
c = and(2, cd);
for (int i = 0; i < c->as; i += 1) {
for (int j=0; j < c->ci[i]->as; j++) {
printf("%d \n", c->ci[i]->a[j]);
}
}
free(cd);
free(c);
}//main
实际结果:
0
1
2
3
预期结果:
0
1
2
3
0
1
2
3
struct Code *c = malloc(sizeof (struct Code)+as * sizeof (struct Codes));
不正确。结构代码的 ci 是一个指针数组,但您为结构数组分配了 space。
要解决此问题,请更改为 sizeof(struct Codes *)
,或者最好使用 dereferencing 指向您正在为 space 分配的类型的指针的模式:
struct Code *c = malloc( sizeof *c + as * sizeof c->ci[0] );
另外,for (int j;
应该是 for (int j = 0;
。您的代码通过使用 j
的未初始化值导致未定义的行为,这只是您碰巧得到您所做的输出的机会。使用 gcc 标志 -Wextra
会诊断出此错误。
我想知道如何将包含 int 数组的结构分配给结构数组。无论我想到什么新的解决方案,我总是得到不正确的结果。
我认为问题出在这段代码中:
struct Codes *create(int as) {
struct Codes *c = malloc(sizeof (struct Codes)+as * sizeof (int));
c->as = as;
for (int i = 0; i < as; i++) {
c->a[i] = i;
}
return c;
}
全部代码:
#include <stdio.h>
#include <stdlib.h>
#include <ctype.h>
struct Codes {
int as;
int a[];
};
struct Code {
int as;
struct Codes *ci[];
};
struct Codes *create(int as) {
struct Codes *c = malloc(sizeof (struct Codes)+as * sizeof (int));
c->as = as;
for (int i = 0; i < as; i++) {
c->a[i] = i;
}
return c;
}
struct Code *and(int as, struct Codes *cd) {
struct Code *c = malloc(sizeof (struct Code)+as * sizeof (struct Codes));
for (int i = 0; i < as; i++) {
c->ci[i] = cd;
}
c->as = as;
return c;
}
int main(int argc, char **argv) {
struct Codes *cd;
cd = create(4);
struct Code *c;
c = and(2, cd);
for (int i = 0; i < c->as; i += 1) {
for (int j=0; j < c->ci[i]->as; j++) {
printf("%d \n", c->ci[i]->a[j]);
}
}
free(cd);
free(c);
}//main
实际结果:
0
1
2
3
预期结果:
0
1
2
3
0
1
2
3
struct Code *c = malloc(sizeof (struct Code)+as * sizeof (struct Codes));
不正确。结构代码的 ci 是一个指针数组,但您为结构数组分配了 space。
要解决此问题,请更改为 sizeof(struct Codes *)
,或者最好使用 dereferencing 指向您正在为 space 分配的类型的指针的模式:
struct Code *c = malloc( sizeof *c + as * sizeof c->ci[0] );
另外,for (int j;
应该是 for (int j = 0;
。您的代码通过使用 j
的未初始化值导致未定义的行为,这只是您碰巧得到您所做的输出的机会。使用 gcc 标志 -Wextra
会诊断出此错误。