C标准库函数实现之strstr
昨天去参加一个面试,发现自己的代码水平还是不够,连基本的标准库实现,都没法做好,遂决定对标准库中的部分函数的实现研习一番。
面试的是 char* strstr( char* s1 , char* s2 )函数,自己写的就不说了,写得很烂,不过看了minix代码,里面的实现思路和我一样,Linux的代码中,对这个函数有用汇编来进行实现的,暴汗……
看下Linux下的实现:
char *strstr(const char *s1, const char *s2) { size_t l1, l2; l2 = strlen(s2); if (!l2) return (char *)s1; l1 = strlen(s1); while (l1 >= l2) { l1--; if (!memcmp(s1, s2, l2)) return (char *)s1; s1++; } return NULL; }
思路:
检测字符串安全性,s2为空果断抛弃之。
s1逐个递增,并与s2整串比较内存大小,判断字串是否相等。相等则返回s1,否则s1++,再执行比较。
最后返回空值,代表未找到相符的串
总的来说,这个函数的实现是相当简单的,昨天却没有将它完整答对,虽然思路正确了,但是coding能力不仅在于思路,更在于how to code fast and right。
路漫漫其修远兮,吾将上下而求索。
posted on 2011-11-01 14:25 Phoe Wang 阅读(5454) 评论(1) 编辑 收藏 举报