我在 C (Ubuntu 10.10) 中创建了一个 UDP 服务器。服务器非常大,其中一部分使用 Strtok_r() 进行了一些字符串处理[我之前已经成功使用过这个函数]。当服务器第一次运行时,它会正确处理来自客户端的数据。但是当另一个客户端出现并发送一些数据时,程序崩溃并显示以下消息:
MappingServer: malloc.c:3096: sYSMALLOc: Assertion `(old_top == (((mbinptr) (((char *) &((av)->bins[((1) - 1) * 2])) - __builtin_offsetof (struct malloc_chunk, fd)))) && old_size == 0) || ((unsigned long) (old_size) >= (unsigned long)((((__builtin_offsetof (struct malloc_chunk, fd_nextsize))+((2 * (sizeof(size_t))) - 1)) & ~((2 * (sizeof(size_t))) - 1))) && ((old_top)->size & 0x1) && ((unsigned long)old_end & pagemask) == 0)' failed.
Aborted
如果我注释掉 strtok_r() 函数,那么一切正常(无论有多少客户来!)。导致问题的代码是:
char delims[] = "/";
char* token = NULL;
char* separated_token[4];
int i,j;
char* last;
j = 0;
token = strtok_r( input_string, delims, &last );
while( token != NULL)
{
separated_token[j] = malloc(strlen(token) + 1);
strcpy(separated_token[j],token);
printf("%s ", separated_token[j] );
j++;
token = strtok_r( NULL, delims, &last );
}
据我所知,代码没问题,它适用于第一个客户。我有点困惑,这个错误是什么意思?我试过 strtok() ,结果是一样的。