为什么Valgrind报告"无效读取大小2和#34;?

时间:2014-10-28 04:04:07

标签: c

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) 

1 个答案:

答案 0 :(得分:2)

我得到了“无效读取大小2”,尝试malloc() 2x2单通道纹理(4个字节/ uint8_t s)。我假设分配太小 - 所讨论的架构上的字大小是8字节(64位) - 所以我将分配加倍并且它停止了valgrind的抱怨。由于malloc()应该是对齐的,我对此感到有点惊讶(我确信这对专家来说是显而易见的),但也许它会帮助别人。没有义务使用额外分配的空间,它只需要在那里。

......即使它没有带来洞察力,这也是一个解决方案。 gcc 4.9.1(Ubuntu 4.9.1-16ubuntu6)发生问题。