分析:
前两天在写测试用例的时候发现了一个段错误的bug,最后在追踪代码的时候发现问题出在strdup函数上面,结论是,该函数的参数不能为NULL,一旦为NULL,就会报段错误。
出于对问题的探索,我又自己写了一些写测试:
(1)
#include <string.h>
intmain()
{
const char *null_src_p = NULL;
char *null_dest_p = strdup(null_src_p);
return 0;
}
最终在执行的时候还是报:Segmentation fault
(2)
我找到了strdup的源代码:
char *strdup1(const char *str)
{
size_t len;
char *copy;
len = strlen(str) + 1;
if ((copy = malloc(len)) == NULL)
return (NULL);
memcpy(copy, str, len);
return (copy);
}
继续跟踪发现为题出来strlen,结论:strlen函数参数不能为NULL;
(3)我想strlen参数不能是NULL似乎又是另外一个问题了,且听下回继续分解了。
建议:
大家以后再使用strdup的时候千万别忘记了对参数的判断和检查。
前两天在写测试用例的时候发现了一个段错误的bug,最后在追踪代码的时候发现问题出在strdup函数上面,结论是,该函数的参数不能为NULL,一旦为NULL,就会报段错误。
出于对问题的探索,我又自己写了一些写测试:
(1)
#include <string.h>
intmain()
{
const char *null_src_p = NULL;
char *null_dest_p = strdup(null_src_p);
return 0;
}
最终在执行的时候还是报:Segmentation fault
(2)
我找到了strdup的源代码:
char *strdup1(const char *str)
{
size_t len;
char *copy;
len = strlen(str) + 1;
if ((copy = malloc(len)) == NULL)
return (NULL);
memcpy(copy, str, len);
return (copy);
}
继续跟踪发现为题出来strlen,结论:strlen函数参数不能为NULL;
(3)我想strlen参数不能是NULL似乎又是另外一个问题了,且听下回继续分解了。
建议:
大家以后再使用strdup的时候千万别忘记了对参数的判断和检查。
作者:androidzhaoxiaogang 发表于2013-1-1 0:19:30 原文链接
阅读:45 评论:0 查看评论