描述一
char *p = “abcd1111abcd2222abcd333” 请找出abcd出现的次数
要求1 :自定义一个接口(函数),并实现功能
要求2 :编写测试用例
api分析
实现一个函数 --> get_count()
参数分析 a.需要查找的子串 b.待查找的子串 c.输出的结果
a.需要查找的子串 --> 需要查找的子串整个存放的内存空间 --> 需要子串的首地址 = char *str
b.待查找的子串 -> 待查找的子串整个存放的内存空间 --> 需要待查找子串的地址 = char *sub_str
c.输出的结果 -> 函数里需要改变该变量 --> 输出结果的地址 = int *count
返回值 : 用来表示该函数运行是否成功
写出接口
1.主函数
void main()
{
int ret =0;
char *p = "abcd1111abcd2222abcd333"; //字符在全局区,p的值在栈,让p的值为字符的首地址
int n_count =0;
char *subp = "abcd";
ret = get_count(p,subp,&count);
if( ret != 0)
{
printf("func get_count() err:%d \n",ret);
return ;
}
printf("countn:%d \n",n_count);
}
2.注意点
要注意别人调用我们的api,判断提供的参数是否可以用
函数里的参数,相当于放在函数内部,要注意函数的内存释放 eg:
int get_count(int a, char *p)
{
return 0;
}
// 相当于下面的函数,从这里注意函数里变量内存的释放
int get_count()
{
int a;
char *p;
return 0;
}
3.构造api
int get_count(char *str,char *substr, int *count)
{
int rv =0;
char *p = str;
int ncount =0;
if( str ==NULL || substr== NULL || count == NULL)
{ //别人传递的参数可能有问题
rv = -1;
printf("func get_count()check ( str ==NULL || substr== NULL || count == NULL) err:%d\n",rv);
return rv;
}
do
{
p = strstr(p,substr);
if(p ==NULL)
break;
else
{
ncount++;
p = p + strlen(substr);
}
}while(*p != '\0');
*count = ncount;
printf("ncount:%d\n",ncount);
return rv;
}