memset을 사용하여 구조체 유형의 배열 셀을 초기화하려고합니다. 프로그램은 성공적으로 컴파일되지만 Valgrind는 이러한 셀을 memseting하는 것과 관련된 것에 만족하지 않습니다. 주석 처리 된 코드도 작동하지 않습니다.
#include <stdio.h>
#include <assert.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#define MAX_DATA 512
#define MAX_ROWS 100
struct Address {
int id;
int set;
char name[MAX_DATA];
char email[MAX_DATA];
};
struct Database{
struct Address rows[MAX_ROWS];
};
struct Connection{
FILE* file;
struct Database* db;
};
void die(const char* message)
{
if(errno){
perror(message);
}else{
printf("ERROR: %s\n", message);
}
exit(1);
}
void Database_load(struct Connection* conn)
{
int rc = fread(conn->db, sizeof(struct Database), 1, conn->file);
if (rc != 1)
{
die("Failed to load database.");
}
}
struct Connection* Database_open(const char* filename, char mode)
{
struct Connection* conn = malloc(sizeof(struct Connection));
if (!conn)
{
die("Memory error");
}
if (mode == 'c')
{
conn->file = fopen(filename, "w");
}
else
{
conn->file = fopen(filename, "r+");
if(conn->file) {
Database_load(conn);
}
}
if(!conn->file) die("Failed to open file");
return conn;
}
void Database_create(struct Connection* conn)
{
int i = 0;
for(i = 0; i < MAX_ROWS; i++) {
//struct Address addr = {.id = i, .set = 0};
//conn->db->rows[i] = addr;
memset(&(conn->db->rows[i]), 0, sizeof(struct Address));
conn->db->rows[i].id = i;
}
}
int main(int argc, char* argv[])
{
if(argc < 3) die("USAGE: ex17 <dbfile> <action> [action params]");
char* filename = argv[1];
char action = argv[2][0];
struct Connection* conn = Database_open(filename, action);
int id = 0;
if(argc > 3) id = atoi(argv[3]);
if(id >= MAX_ROWS) die("There's not that many records.");
Database_create(conn);
return 0;
}
관련 Valgrind 오류-
==16227== Conditional jump or move depends on uninitialised value(s)
==16227== at 0x4C3009C: memset (vg_replace_strmem.c:1224)
==16227== by 0x400BA8: Database_create (ex17.c:108)
==16227== by 0x400EE1: main (ex17.c:174)
코드가 초기화되지 않습니다. conn->db
다음과 같은 것이 필요합니다.
conn->db = malloc(sizeof(struct Database));
if (!conn->db)
{
die("Memory error");
}
Database_open
기능 내부
이 기사는 인터넷에서 수집됩니다. 재 인쇄 할 때 출처를 알려주십시오.
침해가 발생한 경우 연락 주시기 바랍니다[email protected] 삭제
몇 마디 만하겠습니다