我想解析一个字符串,并且使用strsep
函数:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
char str[] = "Marco:Q:2F7PKC";
char *token1, *token2, *token3;
char *r = malloc(30);
strcpy(r, str);
token1 = strsep(&r, ":");
token2 = strsep(&r, ":");
token3 = strsep(&r, ":");
printf("tok1 = %s\n", token1);
printf("tok2 = %s\n", token2);
printf("tok3 = %s\n", token3);
free(r);
return 0;
}
该函数可以很好地完成工作,但是如果我启动valgrind,分配的字符串将char * r
无法正确释放(肯定会丢失:1个块中有30个字节)。
我想知道为什么以及是否有其他方法可以做同样的事情,也许不需要调用strsep。
我打电话给valgrind valgrind --tool=memcheck --leak-check=full --show-reachable=yes ./a.out
strsep
覆盖其第一个(指针到指针)参数的目标,因此您将丢失指向malloc
“ d缓冲区”基址的指针。实际上,如果确实printf("%p\n", r);
在之前放置了free
,则您将发现释放的空指针无效。
一种简单的解决方案是引入一个额外的变量,以free
在完成操作后保留该指针。习惯用法是
char *r = strdup("Marco:Q:3F7PKC");
// check for errors
char *tok = r, *end = r;
while (tok != NULL) {
strsep(&end, ":");
puts(tok);
tok = end;
}
free(r);
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句