struct item
{
int a;
};
int main()
{
item *a = (item *)malloc(sizeof(item));
item *b = (item *)malloc(sizeof(item));
short *c = (short *)b;
c += 3;
memcpy(a, c, sizeof(int));
free(a);
free(b);
return 0;
}
为什么valgrind
回显"无效读取大小2"?我认为应该是4号。
来自Valgrind的示例消息:
==19134== Invalid read of size 2
==19134== at 0x4C2F7E0: memcpy@@GLIBC_2.14 (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==19134== by 0x400625: main (main.cpp:19)
==19134== Address 0x51fd096 is 2 bytes after a block of size 4 alloc'd
==19134== at 0x4C2AB80: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==19134== by 0x4005FC: main (main.cpp:16)
答案 0 :(得分:2)
我得到了“无效读取大小2”,尝试malloc()
2x2单通道纹理(4个字节/ uint8_t
s)。我假设分配太小 - 所讨论的架构上的字大小是8字节(64位) - 所以我将分配加倍并且它停止了valgrind的抱怨。由于malloc()
应该是对齐的,我对此感到有点惊讶(我确信这对专家来说是显而易见的),但也许它会帮助别人。没有义务使用额外分配的空间,它只需要在那里。
......即使它没有带来洞察力,这也是一个解决方案。 gcc 4.9.1(Ubuntu 4.9.1-16ubuntu6)发生问题。