[英]C: SEGFAULT with realloc on char **
我在这段代码中遇到的另一个问题。 我具有低于该比较功能arg
用的字符串数组中的每个串reference
:
char compare(char *arg)
{
int iter=0;
char retchar='0';
while(iter < no_of_ref)
{
// printf("arg : %s , reference : %s \n",arg,reference[iter]);
if((strstr(reference[iter],arg) != NULL) || (strstr(arg,reference[iter]) != NULL))
{
retchar='1';
break;
}
iter++;
}
return retchar;
}
reference
是全局char **
,但是在main中动态构建如下:
reference = calloc(CHUNK, sizeof(char *));
然后是一些代码,然后:
temp_in[pre_pip+1]='\0';
reference[no_of_ref]=malloc(strlen(temp_in) + 1);
strcpy(reference[no_of_ref++],temp_in);
memset(&temp_in,'\0',sizeof(temp_in));
pre_pip = -1;
printf("INDEX: %d, address : %p , val : %s\n",no_of_ref-1,reference[no_of_ref-1],reference[no_of_ref-1]); //DEBUG
}
/*If allocated buffer is at brim, extend it for CHUNK char * further*/
if(no_of_ref == (tr*CHUNK - 2))
{
current_size = tr*CHUNK*sizeof(char *);
char *retalloc = realloc(reference,current_size + CHUNK*sizeof(char *));
if(retalloc == NULL)
perror("ERROR on realloc");
else
{
printf("Realloced successfully: %p\n",retalloc);
tr++;
}
对于不需要realloc
测试用例运行的代码运行正常,即输入字符串数小于CHUNK
。 在realloc
情况下,我从函数中得到SEGFAULT
。 以下是其中一个运行:
Program terminated with signal 11, Segmentation fault.
#0 __strstr_sse42 (s1=0x3839393433333230 <Address 0x3839393433333230 out of bounds>, s2=0x6020c0 <cmp> "8956549122")
你需要在realloc()
括号表达式
//---------------------------------v -------------------v
char *retalloc = realloc(reference,(current_size + CHUNK)*sizeof(char *));
假设CHUNK=100
且current_size=200
,您的代码将分配200+100*8=1000 bytes
而您想要(200+100)*8 = 2400 bytes
此外,请确保在重新分配retalloc
分配给reference
变量。
当realloc
实际重新分配您传递给它的内存时,您作为参数传递的指针仍然指向旧的内存区域。 realloc
函数返回指向新内存的指针,因此您必须将其指定给例如reference
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.