21

我遇到了 valgrind 的问题:这是我的程序(以及出现错误的主要部分):

int main()
{
char comanda[N];
....
char *p;
while( fgets(comanda,100,stdin)!=NULL)
    {
    p=strtok(comanda," \n");
    if (strcmp(comanda,"INIT")==0)
        {
        p=strtok(NULL," ");
        Init(n);        
        }
395 >>if (strcmp(p,"DUMP")==0)
        {
        Dump(n);}
    if (strcmp(p,"ALLOC")==0)
        {
        Alloc(j,n);
        }
    ....return 0;}

当我运行 valgrind 时,它说:

Invalid read of size 1
at 0x401569: main (:395)
Address 0x0 is not stack'd malloc'd or (recently) free'd

我无法弄清楚这个程序有什么问题。

4

2 回答 2

32

如何阅读:

大小为 1 的无效读取

你的程序试图从 Valgrind 不喜欢的地方读取一个字节。

在 0x401569: 主要 (:395)

在代码中发生这种情况的位置(显然 strcmp 已被内联)

地址 0x0 不是堆栈的 malloc'd 或(最近)free'd

它正在读取的地址 - 0x0 是“NULL”。声明的其余部分只是说明它为什么无效(它不是来自堆栈,它不是你从 malloc 获得的东西,并且最近没有被释放)。提到“最近”是因为 valgrind 会跟踪已释放内存的有限数量的释放,所以它不能肯定地说它没有释放一百万个释放 - 在这种情况下它不是,但如果你看到这样的消息,可能是因为它在很久以前被释放而变得无效。该地址不会为零(或接近零)。

于 2012-12-28T09:58:45.250 回答
7

strtok当没有更多令牌时,可以返回 NULL 。

当您将 NULL 传递给它时,当您strcmp在那里取消引用 NULL 时,它是一种未定义的行为。

于 2012-12-28T09:38:21.437 回答