概述
在C的库函数里面有很多精彩的代码,仔细分析会体会到这些写法和思路的巧妙之处。
写strstr函数的时候要判断两个字符换str1和str2什么时候开始匹配,什么时候结束,这两点都是比较容易做到的,难点在于判断到两个字符匹配后如何返回一开始匹配的指针,因为一开始判断两个字符串里面的字符是否匹配时,很容易想到*(str1++)==*(str2++),这样做带来的结果就是想要返回一开始匹配时的指针,但是经过很多次++运算后,指针指向的地址已经发生移动,不能直接返回使用,此时很容易想到在一开始匹配的时候就记录下当时的指针,或者使用strlen(str2)记录向后移动了多少,两种办法虽然都能解决问题,但是会让代码显得很冗长,思路不清晰。反观C库函数中strstr函数的写法,利用创建的局部变量i在逐个匹配字符时利用*(str1+i)==*(str2+i)来做判断,即达到了移动地址的目的,同时指针也没有发生变化,显得十分巧妙,同样的巧妙之处在C的库函数里数不胜数,所以多看C的库函数也是提升写代码能力的不错的途径。
char *mystrstr(char *str1,char *str2)
{
int i=0;
assert(*str1&&*str2);
if(*str2)
{
while(*str1)
{
for(;*(str1+i)==*(str2+i);i++)
{
if(!*(str2+i+1))
{
return str1;
}
}
str1++;
}
}
else
{
return str1;
}
}
最后
以上就是懦弱歌曲为你收集整理的strstr函数的精彩之处的全部内容,希望文章能够帮你解决strstr函数的精彩之处所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复