0

我写了一个函数,参数是历史类型的结构。该结构包含一个 char 2d 数组,其大小是动态分配的。

所以这里是函数:

void appendLine(Historique** hist, const char* str){

    int size, i, sizestr;

    size=(*hist)->size;
    sizestr=strlen(str);

    History* tmp;

    tmp=NULL;
    tmp=(struct History*)malloc(sizeof(hist));

    copyHist(&tmp, *hist);

    freeHist(*hist);

    *hist=NULL;

    *hist=(struct History*)malloc(sizeof(History));

    (*hist)->size=tmp->size;

    if(((*hist)->line=(char**)malloc(sizeof(char)*size+sizeof(char)))==NULL){
        printf("ERROR !");
        exit(EXIT_FAILURE);
    }

    if((((*hist)->ligne)[taille]=(char*)malloc(sizeof(char)*strlen(str)+sizeof(char)))==NULL){
        printf("ERROR !");
        exit(EXIT_FAILURE);
    }

    for(i=0; i<taille; i++){
        (*hist)->ligne[i]=(char*)malloc(sizeof(char)*strlen(tmp->line[i])+sizeof(char));
        memcpy((*hist)->ligne[i], (tmp->line)[i], sizeof(char)*strlen(tmp->line[i]));
        (*hist)->line[i][strlen(tmp->line[i])]='\0';
    }

    for(i=0;i<sizestr;i++){
        (*hist)->line[size][i]=str[i];
    }   

    (*hist)->line[size][strlen(str)]='\0';

    (*hist)->size+=1;

    tmp=NULL;
}

void copyHist(History** dest, const History* src) {
    int i,j;
    (*dest)->line=NULL;
    (*dest)->line=(char **)malloc(sizeof(char)*src->size);
    for(i=0; i<src->size; i++){
        if(((*dest)->line[i]=malloc(sizeof(char)*strlen(src-   >line[i])+sizeof(char)))==NULL){
            printf("ERROR!");
            exit(EXIT_FAILURE);
        }
        for(j=0;j<strlen(src->line[i]);j++){
            (*dest)->line[i][j]=(src->line)[i][j];
        }   
        (*dest)->line[i][j]='\0';
    }
    memmove(&((*dest)->size), &(src->size), sizeof(int));
}

void freeHist(History* arg){
    int i;

    for(i=0; i<arg->size; i++){
        free(arg->line[i]);
        arg->line[i]=NULL;
    }
    free(arg);
    arg=NULL;
}

所以一切似乎都很好,除了当我一个接一个地添加几行时, at 的行index 0没有显示正确的东西。

非常感谢您的关心

4

0 回答 0