我正在编写一个包含“info”类型信息的简单数据库的代码。
这是我的代码:
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#define NAME_LENGTH 20
#define EMAIL_LENGTH 15
struct info {
char name[NAME_LENGTH];
char email[EMAIL_LENGTH];
int flag;
};
int createDB(char *name) {
FILE * file = fopen(name, "w+b");
return fclose(file);
}
FILE *openDB(char *name) {
FILE* file = fopen(name, "r+b");
if(file != NULL) return file;
return NULL;
}
int closeDB(FILE *f) {
return fclose(f);
}
struct info *get(FILE *file, int index) {
struct info* temp;
fseek(file, index*sizeof(struct info), SEEK_SET);
fread(temp, 1, sizeof(struct info), file);
if(feof(file) != 0) return NULL;
return temp;
}
int put(FILE *file, int index, struct info *record) {
fseek(file, index*sizeof(struct info), SEEK_SET);
int res = fwrite(record, 1, sizeof(struct info), file);
if(res) return 0;
else return EOF;
}
struct info *search(FILE *file, char *name) {
int k = 0;
struct info* temp = get(file, 0);
do {
if(temp -> flag == 1 && strcmp(temp -> name,name) == 0) return temp;
k++;
temp = get(file, k);
}while(temp != NULL);
return temp;
}
当我从文件中“放”,“获取”信息时,一切正常。但是,当我尝试按名称搜索时,我收到分段错误(核心转储)错误。
请你在这里表明我的错误吗?
答案 0 :(得分:5)
代码
struct info* temp;
...
fread(temp, 1, sizeof(struct info), file);
get
中的尝试将sizeof(struct info)
个字节写入未初始化的指针temp
。您需要为temp
分配内存。
最简单的方法可能是修改get
的签名,以允许调用者从其堆栈中使用info
实例
int get(FILE *file, int index, struct info *record) {
fseek(file, index*sizeof(*record), SEEK_SET);
fread(record, 1, sizeof(*record), file);
if(feof(file) != 0) return -1;
return 0;
}
可以像
一样调用struct info record;
if (get(file, 0, &record) == -1) {
/* eof */
}