我盯着这个看了这么久,以至于它们都开始一起运行了。
所以我收到一个瓦尔格林德错误:
==25468== Invalid write of size 4
==25468== at 0x52CF64D: _IO_vfscanf (vfscanf.c:1857)
==25468== by 0x52D730A: __isoc99_fscanf (isoc99_fscanf.c:35)
==25468== by 0x402DDB: loadMindRAW (gplib.c:172)
==25468== by 0x4047EE: loadAgent (gplib.c:739)
==25468== by 0x4048BD: loadAgentsFromFile (gplib.c:799)
==25468== by 0x4010C3: initRound (gpfight.c:220)
==25468== by 0x400EBE: main (gpfight.c:99)
==25468== Address 0x584388d is 253 bytes inside a block of size 256 alloc'd
==25468== at 0x4C2B6CD: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
这是罪犯:
void loadMindRAW(FILE* f_file, unsigned char* mind)
{
int i;
for(i=0; i < MIND_SIZE; i++)
{
fscanf(f_file,"%d,",&(mind[i]));
}
}
传入的无符号字符数组在之前被错误定位:(MIND_SIZE是256(
tmpAgent->mind = malloc(MIND_SIZE*sizeof(unsigned char));
loadMindRAW(f_file, tmpAgent->mind);
我是否正确指出了我脑海中的地址? &(mind[i])
似乎有点笨拙。原始指针操作,mind+i
具有相同的行为。我在这里错过了一些简单的东西吗?
您正确指向该地址,但您可能不会传递指向unsigned char
的指针,以fscanf
处于需要int
指针的位置。这是因为fscanf
看到%d
说明符,它假设可变参数列表中的相应位置是指向有符号int
的指针;由于 varargs 在 C 和 C++ 中的实现方式,fscanf
没有其他方法可以做到这一点。
以下是您应该如何重写循环:
for(i=0; i < MIND_SIZE; i++)
{
int tmp;
fscanf(f_file,"%d,",&tmp);
mind[i] = (unsigned char)tmp;
}