重新分配两次后发生段错误

时间:2019-04-27 21:04:52

标签: c segmentation-fault realloc

我试图编写一个函数,该函数接受输入而没有给出长度。当我尝试获得一个输入时,它是可行的,但是如果我想获得多个输入,则会出现段错误。下面是代码:

char* getinput()
    {
    char c,*str=0,*tmp=0;
    int i=0;

    while(c)
    {
            c=getchar();

            if(c!=EOF && c!='\n')
        {
            if(!(tmp=realloc(str,(i+1)*sizeof(char))))
            {
            free(str);
            return NULL;
            }

        str=tmp;
        str[i++]=c;
        }
        else c=0;
    }

    str[i]=0;
    return str;
}

当我尝试获得单个输入时,我可以打印字符串:

string1      
string1

当我尝试获取多个输入时,我不能:

string1
Segmentation fault (core dumped)

还有另一个变量string2。感谢您的帮助。谢谢。

1 个答案:

答案 0 :(得分:1)

假设您输入了一个字符

您将分配一个一个字节的缓冲区,将字符写入其中,然后增加索引并执行以下操作:

str[i]=0;

这时i==1,您正在str分配的边界之外书写:未定义的行为

我建议您将缓冲区大小增加一:

if(!(tmp=realloc(str,(i+2)))

(并降低sizeof(char)位,因为它保证为1)

一种更有效的技术是“不时地”重新分配,像大多数矢量分配器一样,而不是每次都跟​​踪分配的缓冲区的容量。