楼主:
deo2000 (800IM)
2016-10-06 11:37:51这个 function 主要是将自己写的 Key&Value struct link list
串成一个 QueryString
大约一半机率会发生如下错误:
*** Error in
`/home/lky/workspace/*******************': free():
invalid next size (normal): 0x00000000021297e0 ***
想请版友帮忙诊断一下,是不是哪边内存处理有缺失?
//用来组合 QueryString 的 node
struct listKeyValuePair
{
char* strKey;
char* strValue;
//Link list
struct listKeyValuePair* perv;
struct listKeyValuePair* next;
};
//用来把 listKeyValuePair 已经串起的整个 Link List 转换成单一 QueryString
char* ConvertToQueryString(struct listKeyValuePair* node)
{
char* strQueryString = (char*)calloc(sizeof(char),0);
while(NULL != node)
{//一个接一个按照QueryString格式串上去
size_t newLength =
strlen(strQueryString)+strlen(node->strKey)+strlen(node->strValue)+3;
strQueryString = (char*)realloc(strQueryString, newLength);
if(NULL == node->perv)
{//第一个
sprintf(strQueryString, "%s=%s",node->strKey,
node->strValue);
}
else
{//第二个以后
sprintf(strQueryString, "%s&%s=%s", strQueryString,
node->strKey,
node->strValue);
}
node = node->next;
}
//puts(strQueryString);
return strQueryString;
}
向calloc申请0个位置?而且参数前后好像放错了,小弟乱猜的内存那么便宜了,不用那么节检吧XDXD
用snprintf看了一下所以你一直realloc吗 为何不算长度一次配完内存
calloc(1,0)回传值是什么呢,没空间的空间,三次元吗而且return字串的char*真的很少见的写法,有创意正常应该是把字串空间先创好,在给进含数的参数运用
作者:
LPH66 (-6.2598534e+18f)
2016-10-06 13:35:00楼上好像讲到重点了: calloc 的参数是 (个数, 元素大小)并不是 (总长度, 内容值), 所以应该要写 calloc(1,1) 才对calloc 一定会填 0 所以也不用自己写 0原 PO 你试试最一开始的写法但把 (1,0) 换成 (1,1) 看看newLength 其实只要 +1 即可, 但 +3 其实也无妨就是咦不对, 我错了...你有中间连接的字串所以需要 +3 没错