我有一个包含一系列交易的BankAccount结构。存款和取款在此数组中以+/-整数存储。
struct BankAccount {
char name[NAME_LENGTH];
int num_of_transactions;
int transactions[MAX_TRANSACTIONS];
};
我为堆上的struct分配空间并在完成后处理它。我使用fwrite将此结构保存到文件。
struct BankAccount *new_bank_account(char name[], int initial_deposit) {
struct BankAccount *acc = malloc(sizeof(struct BankAccount));
strncpy(acc->name, name, NAME_LENGTH);
acc->num_of_transactions = 0;
int i;
for (i = 0; i < MAX_TRANSACTIONS; i++) {
acc->transactions[i] = 0;
}
if (initial_deposit != 0) {
make_deposit(acc, initial_deposit);
}
return acc;
}
void delete_bank_account(struct BankAccount *acc) {
free(acc);
}
int save_bank_account(struct BankAccount *acc, char filepath[]) {
FILE *fp = fopen(filepath, "w");
int res = 0;
res = fwrite(acc, sizeof(struct BankAccount), 1, fp);
fclose(fp);
return res;
}
代码按预期工作,我可以在帐户上进行交易并将其保存到磁盘并重新加载。我的测试代码如下。
void test_bank_account_balance() {
struct BankAccount *acc = new_bank_account("John Doe", 0);
make_deposit(acc, 50);
make_deposit(acc, 100);
make_withdrawal(acc, 50);
printf("%s has balance = $ %d\n", acc->name, get_balance(acc));
delete_bank_account(acc);
}
int main(int argc, char *argv[]) {
test_save_bank_account();
return 0;
}
然而,当我通过valgrind运行它时,它给出了有关未初始化字节的错误。我怀疑new_bank_account中缺少一些初始化。但我无法看到那是什么。
==4311== Syscall param write(buf) points to uninitialised byte(s)
==4311== at 0x411E1D3: __write_nocancel (syscall-template.S:82)
==4311== by 0x40B2B04: _IO_file_write@@GLIBC_2.1 (fileops.c:1289)
==4311== by 0x40B29E3: new_do_write (fileops.c:543)
==4311== by 0x80489B0: test_save_bank_account (p14.c:124)
==4311== by 0x8048A1D: main (p14.c:140)
==4311== Address 0x4035032 is not stack'd, malloc'd or (recently) free'd
==4311== Uninitialised value was created by a heap allocation
==4311== at 0x402BD14: malloc (vg_replace_malloc.c:270)
==4311== by 0x80486B5: new_bank_account (p14.c:41)
==4311== by 0x8048956: test_save_bank_account (p14.c:118)
==4311== by 0x8048A1D: main (p14.c:140)
请帮忙!感谢。
答案 0 :(得分:5)
我猜测name
的{{1}}和num_of_transactions
成员之间存在一些填充。
这可能不是什么值得担心的,但如果你想沉默valgrind,使用struct BankAccount
来分配内存应该有效。或calloc()
。