strlen strncat strstr 三种库函数的代码实现

    首先我们来看strlen函数,它主要是求一个字符串的长度,所以返回的应该是int型类型,其主要方法是将字符串从头到尾进行遍历时进行计数,因此实现起来并不是很难,其主要函数代码如下:

int length(char *p)

{

int len = 0;

while (*p != 0)

{

len++;

p++;

}

return len;

因为字符长度是不包括‘\0’,所以返回时不用进行+1操作。

    然后是关于strncat函数的实现,它主要是对两个字符串进行有个数的连接,注意,是有个数的连接,这也是它和strcat不同的地方,strcat是将整个字符串追加到另一个字符串上,不够灵活。strncat的主要函数方法就是通过指针赋值的方法将源操作数追加到目的操作数上,当然这里的目的操作数必须是有足够空间的,是能够存放下你所给的字符串长度才行。

具体的代码如下:

void *my_strncat(char *dest, const char *src, int k)

{

assert(dest);

assert(src);

char *tmp = dest;         //将目的操作数保存起来

while (*dest)             //首先将目的操作数指向‘\0’处

{

dest++;

}

while (k)                  //再将源操作数追加上去

{

*dest++ = *src++;

k--;

}

return tmp;

}

    这里要说的是,在你执行这个函数是,要将你的目的操作数保存起来,因为当你执行完整个函数时,你的目的操作数的指针已经指向的不是你字符串的首地址了,而当你要返回时必须返回的是你目的操作数的首地址,因此应提前保存起来。

     最后一个就是strstr函数,其主要目的是找子串,它的主要函数方法是两层循环嵌套,第一层循环是以目的操作数作为循环条件的,它主要是为了找到它与源操作数相等时的起始位置,当找到时再进入源操作数的循环,判断整个源操作数是否为它的子串。

主要函数代码如下:

void *my_strstr(char *dest, const char *src)

{

assert(dest);

assert(src);

char *tmp = NULL;

while (*dest)

{

while (*src)

{

if (*dest == *src)

{

dest++;

src++;

}

else break;

}

if (*src == 0)

{

return tmp;      //返回的是找到时目的操作数的位置

}

else

{

dest++;

tmp = dest;       //找到其相等时的位置

}

}

}

这里注意的还是返回值的问题,它返回的是你目的操作数与源操作数相等时的地址,因此要用指针对其进行标识。


你可能感兴趣的:(return,字符串,空间)