c - 使用 fread 从文件中读取奇怪的文本

标签 c arrays fopen fwrite fread

我在读取写入的文件时遇到问题,它显示奇怪的标记,而不是我尝试打印的文本。这可能只是一个简单的解决方案,但我找不到它。已经在这里坐了好几个小时了! :/

http://imgur.com/syiJCPS

#include <stdio.h>
#include <string.h>
#include <malloc.h>
#include <stdlib.h>
//#include "allafunktioner.h"

struct vinnare{
    int ar;
    char namn[20];
};
struct vinnare *inlasningTillFil(struct vinnare *vinnare, int antalvinnareinlasning);
int meny();

int vinnarear(int ar, char namnlista, int vinnare);
void artistnamn(int ar, char namnlista, int vinnare);
void skrivutalla(int ar, int  namnlista, int vinnare);

main(){
    int a=1, val, antalvinnareinlasning,test=0;

    struct vinnare *vinnare;

    FILE *file;
    file = fopen("F:\\Uppgifter", "rb");

    if (file == NULL){

        vinnare = NULL;
        printf("Ange antal vinnare:");
        scanf("%d", &antalvinnareinlasning);
        vinnare = (struct vinnare *)malloc(antalvinnareinlasning*sizeof(struct vinnare));
        vinnare = inlasningTillFil(vinnare, antalvinnareinlasning);
    }
    else{

        fread(&antalvinnareinlasning, sizeof(int), 1, file);
        printf("%d", antalvinnareinlasning);
        vinnare =(struct vinnare *)malloc(antalvinnareinlasning*sizeof(struct vinnare));

        for (a = 1; a < (antalvinnareinlasning + 1); a++){
            fread(&vinnare[a].ar, sizeof(int), 1, file);
            fread(&vinnare[a].namn, sizeof(char)*20, 1, file);
            printf("%d", vinnare[a].ar);
            printf("%s", vinnare[a].namn);
        }


    }
    fflush(stdin);
    getchar();
}


struct vinnare *inlasningTillFil(struct vinnare *vinnare, int antalvinnareinlasning){
    int a, temp;

    FILE *file;
    file = fopen("F:\\Uppgifter", "wb");

    vinnare[0].ar = antalvinnareinlasning;


    fwrite(&vinnare[0], sizeof(struct vinnare),1, file);


    for (a = 1; a < (antalvinnareinlasning + 1); a++){
        printf("Ange vilket år du vill mata in: ");
        scanf("%d", &temp);
        vinnare[a].ar = temp;
        fflush(stdin);

        printf("Ange vinnaren för det året:");
        fgets(vinnare[a].namn, 20, stdin);
        fflush(stdin);

        fwrite(&vinnare[a], sizeof(struct vinnare), 1, file);
    }

}

最佳答案

当您第一次读入文件时,您会读取一个 int 来表示记录数。

fread(&antalvinnareinlasning, sizeof(int), 1, file);

但是当你编写文件时,你要做的第一件事就是编写一个未初始化的struct vinnare:

fwrite(&vinnare[0], sizeof(struct vinnare),1, file);

因此您的文件格式不一致,最终您的 char 字段中会出现来自 int 的二进制数据。

此外,我建议您以与 fwrite 完全相同的方式执行 fread 操作,以防结构中存在填充。 sizeof(struct vinnare) 不保证与 sizeof(int) + sizeof(char[20]) 完全相同,因此:

fread(&vinnare[a].ar, sizeof(int), 1, file);
fread(&vinnare[a].namn, sizeof(char)*20, 1, file);

不一定相同

fread( &( vinnare[a]), sizeof(struct vinnare), 1, file) ;

最后,您在内存中分配了 N 条记录来存储 struct,但您使用了错误的记录。您需要在 for 中索引 0N-1,而不是 1N > 在 inlasningTillFil 中循环。最后一次读取的位置 &vinnare[N] 无效。

关于c - 使用 fread 从文件中读取奇怪的文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21079455/

相关文章:

c - 这些字符串是否为 fopen() 正确连接?

c - 试图从 c 中的 txt 文件中获取字符串

使用 C 中的一些通用函数调用来调用多个函数

c - 打印字符串数组的部分内容

ruby-on-rails - 如何简化将多个值插入 Ruby 中的数组?

objective-c - 字符串到字符数组

c - 使用 fopen 和测试 NULL 的奇怪 C 行为

c - STM32 printf 和 RTC

c - 输入二维数组

c - 如何使用 long long int 并消除段错误