从C中的二进制文件读取字符串时的访问冲突

时间:2013-11-14 04:02:55

标签: c file binary access-violation

学生程序员在这里。我无法从C中的二进制文件读取输入。存储在文件中的数据是如下所示的结构:

typedef struct reserve{
    char *name;
    char *ic;
    int room_number;
} Reserve;

当我将结构体写入二进制文件时,我没有遇到任何问题。这是我写入文件的代码:

void reg_new() //Make a new reservation
{
    Reserve newReserve = {"", "", 0};
    char name[NAMEFIELD], ic[ICFIELD];
    int room_number;
    FILE *resvptr;

    scanf_s("%s", name, NAMEFIELD);
    scanf_s("%s", ic, ICFIELD);
    scanf_s("%d", &room_number);

    newReserve.name = name;
    newReserve.ic = ic;
    newReserve.room_number=room_number;

resvptr = fopen("reservations.dat", "wb");
fwrite(&newReserve, sizeof(Reserve), 1, resvptr);
fclose(resvptr);

}

以及从文件中读取的代码:

void reg_view() //view a reservation.
{
FILE *seekptr;
Reserve viewReserve = {"", "", 0};
int read;

if ( (seekptr = fopen("reservations.dat", "rb")) == NULL)
{
    puts("Error: file could not be found.");
}
else
{
    while ( !feof(seekptr))
    {
        read = fread(&viewReserve, sizeof(Reserve), 1, seekptr);

        if(read != 0)
        {
        printf("Name: %s\nIC number: %s\nRoom Number: %d\n", viewReserve.name, viewReserve.ic, viewReserve.room_number);
        }
    }
    fclose(seekptr);
}

写入二进制文件并访问读取函数后,立即读取房间号(int值),但两个字符串(名称和IC号)读出为垃圾字符。随后,关闭并重新启动程序,然后尝试从文件中读取将给我一个访问冲突和错误的指针错误。

问题在于从文件中读取字符串。我怀疑是内存泄漏,但我不能肯定地说......有人可以帮忙吗?感谢。

2 个答案:

答案 0 :(得分:1)

您正在编写指向该文件的指针,而不是实际数据。当你从文件中读取指针时,它只是一个你可能无法访问的内存地址,即使你在写入文件的同一进程中执行它(因为它实际上是指向函数范围堆栈的指针)变量)。

如果要以这种方式存储记录,请使函数存储实际的字符串数据而不是指针:

typedef struct reserve{
    char name[NAMEFIELD];
    char ic[ICFIELD];
    int room_number;
} Reserve;

就这样做:

scanf_s("%s", newReserve.name, NAMEFIELD);
scanf_s("%s", newReserve.ic, ICFIELD);
scanf_s("%d", &newReserve.room_number);

答案 1 :(得分:0)

结构由整数和两个数组(指针)的地址组成。当你把它写出并再读回来时,你正在读写字符数组的地址 - 而不是它们的内容。您需要修改例程以编写和读取内容(包括长度),并在重新读取内容时分配存储以保存内容。