1

如何为结构内的 char 变量(不是 char 指针)分配内存?
(变量名称是葡萄牙语,如果有点令人困惑,请见谅)

我有这个结构:

typedef struct node{
    char rotulo[10], instrucao[1][2][10], flag;
    int simplificado;

    struct node *referencias[2];
    struct node **antecessores;
    int nrAntecessores;

    struct node *ant;
    struct node *prox;
} Estado;

这是insere()设置从新节点中的输入文件读取的值的函数:

void Insere(char *rotulo, char instrucao[][2][10], int qtdInstrucao, char flag){
    int i,j;
    Estado *NovoEstado;
    NovoEstado = (Estado*)malloc(sizeof(Estado));
    NovoEstado->prox = NULL;
    NovoEstado->ant = P->ult;
    strcpy(NovoEstado->rotulo, rotulo);
    NovoEstado->flag = flag;
    NovoEstado->antecessores = NULL;
    NovoEstado->nrAntecessores = 0;
    NovoEstado->simplificado = 0;

    for(i=0;i<qtdInstrucao;i++){
        realloc(NovoEstado->instrucao, i+1*sizeof(char[2][10]));
        strcpy(NovoEstado->instrucao[i][0], instrucao[i][0]);
        strcpy(NovoEstado->instrucao[i][1], instrucao[i][1]);
    }
}

NovoEstado->flag = flag;不起作用......
在我设置它之后,如果我打印NovoEstado->flag我得到正确的值,但如果我for在函数结束时将它放在后面,当我打印时NovoEstado->flag我得到 NovoEstado->rotulo 的第一个字符...
当我尝试打印时也会发生同样的flag情况main()...

我认为那是因为我没有正确分配内存空间flagin Insere(),对吗?我该如何解决?

我很确定这是一个非常简单的问题,而且我可能曾经知道这一点,但我忘记了并且在任何地方都找不到它......所以任何帮助将不胜感激

编辑

按照 ocdecio 的提示,我创建了一个指向二维数组的指针,以便获得一个动态的 3 维数组。
我的目标是有一个像这样的“表”:

  10 chars | 10 chars  
|__________|__________|
|__________|__________|
|__________|__________|

行数是动态的,但它始终是 2 个 10 个字符的字符串的数组。

所以现在这就是我在主要做的事情:

    char estado[127], rotulo[10], strInstrucoes[117], *conjunto = calloc(21, sizeof(char)), flag;
    char (*instrucao)[2][10];

    FILE * entrada;
    Automato *Aut = (Automato*)malloc(sizeof(Automato));

    if((entrada = fopen(argv[1], "r")) != NULL){
        CriaAutomato(Aut);
        while(fgets(estado, 127, entrada)){
            flag = 0;
            sscanf(estado,"%[^:]: %[^;]; %c", rotulo, strInstrucoes, &flag);
            instrucao = calloc(1, sizeof(char[2][10]));
            conjunto = strtok(strInstrucoes,"() ");
            for(i = 0; conjunto != NULL; i++){
                realloc(instrucao, i+1*sizeof(char[2][10]));
                sscanf(conjunto,"%[^,],%s", instrucao[i][0], instrucao[i][1]);
                printf("%s || %d\n", instrucao[i][1], i);
                conjunto = strtok(NULL, "() ");
            }
            Insere(Aut, rotulo, instrucao, i, flag);
            free(instrucao);
        }
        fclose(entrada);

但这不起作用...
这是从文件中读取的输入

adsasdfg2: (abc,123) (def,456) (ghi,789);

但即使在我打电话之前,我Insere也没有按照我想要的方式分配正确的值instrucao,因为这是那个输出printf

123
454
789

而不是我的目标

123
456
789

怎么了?

(在有人问之前,这是作业一部分,但不是作业。我的任务是制作一个确定性有限自动机最小化器,这只是我得到的与数据输入相关的错误)

非常感谢

4

4 回答 4

7

您的问题很可能出在这一行:

realloc(NovoEstado->instrucao, i+1*sizeof(char[2][10]));

无需在结构内分配任何内容,因为该字段instrucao是由语句静态定义的instrucao[1][2][10],它不是动态分配的结构。

于 2009-06-21T14:39:14.083 回答
1

我认为这条线是问题所在:

realloc(NovoEstado->instrucao, i+1*sizeof(char[2][10]));

在结构中,指令被定义为一块连续的内存,但您现在正在分配内存并分配指针。

尝试将其注释掉,您不需要为该变量分配内存。

于 2009-06-21T14:39:43.630 回答
0

您不需要分配标志。它是在结构内定义的字符(与指针相反)。

您的错误是由在您写入的 for 循环期间覆盖结构内的标志内容引起的NovoEstado->instrucao(即它的内存涂鸦或覆盖)。

更新:正如@ocdecio 指出的那样,您不需要在循环内重新分配,因为instrucao它也是静态分配的。

于 2009-06-21T14:39:18.777 回答
0

我不知道代码的意图,但执行以下操作肯定是非法的:

realloc(NovoEstado->instrucao, i+1*sizeof(char[2][10]));

基本上,包含结构是使用 malloc 分配的,但所讨论的内部成员是一个静态定义的数组,它不能使用堆重新分配(因为堆管理器只跟踪指向节点的 malloced 指针)。

typedef struct node{ char rotulo[10], instrucao[1][2][10], flag;

如果您希望动态调整指令大小,则必须将其定义为指针类型并单独为其分配内存。

于 2009-06-21T14:47:04.380 回答