Ошибка при чтении файла PMG P5 - PullRequest
0 голосов
/ 08 октября 2018

Я очень старался, и это моя лучшая попытка прочитать файл pmg P5.Но во время выполнения кажется, что я не могу правильно сканировать файл P5 во время чтения.Пожалуйста, помогите мне найти ошибку в моем коде.

#include <stdio.h>
#include <stdlib.h>

struct image{
    int nrow;
    int ncol;
    char s[10];
    int max;
    int **matrix;
};

int **mem_alloc(int,int);
void mem_dealloc(int **,int);
struct image *read_pgm(const char *,struct image *);
void write_pgm(const char *,const struct image *);

int main(){
    struct image *img;
    img=NULL;
    img=read_pgm("C:/MinGW/bin/image_P5.pgm",img);
    write_pgm("C:/MinGW/bin/write_P5.pgm",img);
    mem_dealloc((*img).matrix,(*img).nrow);
    printf("\nDone !\n");
    return 0;
}
int **mem_alloc(int nrow,int ncol){
    int **q;    
    int i,j;
    q=(int **)malloc(nrow*sizeof(int *));
    if(q==NULL){
        fprintf(stderr,"\nMemory allocation failure .\n");
        exit(EXIT_FAILURE);
    }
    for(i=0;i<ncol;i++){
        q[i]=(int *)malloc(ncol*sizeof(int));
        if(q[i]==NULL){
            fprintf(stderr,"\nMemory allocation failure .\n");
            exit(EXIT_FAILURE);
        }
    }
}

void mem_dealloc(int **q,int nrow){
    int i;
    for(i=0;i<nrow;i++){
        free(q[i]);
    }
    free(q);
}

struct image *read_pgm(const char *filename,struct image *img){
    FILE *fp;
    if((fp=fopen(filename,"rb"))!=NULL){
        int i,j;
        unsigned char *r;
        printf("56");
        fscanf(fp,"%s",(*img).s);
        printf("59");
        fscanf(fp,"%d%d%d",&((*img).ncol),&((*img).nrow),&((*img).max));
        printf("%s\n%d %d\n%d",(*img).s,(*img).ncol,(*img).nrow,(*img).max);
        r=(unsigned char *)malloc(sizeof(unsigned char)*((*img).ncol));
        (*img).matrix=mem_alloc((*img).nrow,(*img).ncol);

        for(i=0;i<(*img).nrow;i++){
            if(!(fread(r,sizeof(unsigned char),(*img).ncol,fp)==(*img).ncol)){
                fprintf(stderr,"\nDid not read line %d properly !.\n",i+1);
                exit(EXIT_FAILURE);
            }
            else{
                for(j=0;j<(*img).ncol;j++){
                    ((*img).matrix)[i][j]=((int)r[j] > 127)?(*img).max:0;
                }
            }
        }
        free(r);
        fclose(fp);
        return img;
    }
    else{
        fprintf(stderr,"\nCould not open file :\n");
        exit(EXIT_FAILURE);
    }

}

void write_pgm(const char *filename,const struct image *img){
    FILE *fp;
    if((fp=fopen(filename,"wb"))!=NULL){
        int i,j;
        unsigned char *w;
        fprintf(fp,"%s\n%d %d\n%d\n",(*img).s,(*img).ncol,(*img).nrow,(*img).max);

        w=(unsigned char *)malloc(sizeof(unsigned char)*((*img).ncol));

        for(i=0;i<(*img).nrow;i++){
            for(j=0;j<(*img).ncol;j++){
                w[j]=(unsigned char)((*img).matrix)[i][j];
            }
            if(fwrite(w,sizeof(unsigned char),(*img).ncol,fp)!=(*img).ncol){
                fprintf(stderr,"\nDid not read line %d properly .\n",i+1);
                exit(EXIT_FAILURE);
            }
        }
        free(w);
        fclose(fp);
    }
    else{
        fprintf(stderr,"\nCould not open file %s",filename);
        exit(EXIT_FAILURE);
    }
}

Хорошо, я исправил это! Финал .Здесь и там были некоторые глупые ошибки, которые, надеюсь, исчезли сейчас!

1 Ответ

0 голосов
/ 08 октября 2018

Я не посмотрел весь код, но главная ошибка, которую я вижу, это то, что вы передаете NULL-указатель на read_pgm().Я не понимаю, почему img должен быть указателем, поэтому простое решение - это исправить.Вы по-прежнему передаете указатель на эту структуру на read_pgm(), но read_pgm() не нужно возвращать значение.

int main(){
    struct image img;  // <- Not a pointer
    read_pgm("C:/MinGW/bin/image_P5.pgm", &img); // <- passing pointer to struct
    write_pgm("C:/MinGW/bin/write_P5.pgm", &img);
    .....
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...