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;
}

思路:

  1. 检测字符串安全性,s2为空果断抛弃之。

  2. s1逐个递增,并与s2整串比较内存大小,判断字串是否相等。相等则返回s1,否则s1++,再执行比较。

  3. 最后返回空值,代表未找到相符的串

总的来说,这个函数的实现是相当简单的,昨天却没有将它完整答对,虽然思路正确了,但是coding能力不仅在于思路,更在于how to code fast and right。

路漫漫其修远兮,吾将上下而求索。

posted on 2011-11-01 14:25  Phoe Wang  阅读(5454)  评论(1编辑  收藏  举报

导航