目录
前言
新的一周码字日又开工了,望各位同道多指导多提建议,共同进步。
用法简介(strcpy)
简用
先介绍一波strcpy,弄懂它之后要搞懂strncpy完全是so easy。
char* strcpy(char* dest,char* scr)字符串拷贝函数。
scr为要被拷贝的字符串的首元素地址即可以被叫做源头,dest为存储被拷贝出来的字符串的内存空间地址即可以被叫做目的地。至于返回值,那当然是返回目的地的首元素的地址,要不然拷完后不知道上哪找它去了。
个人感觉,库函数中似乎很喜欢让目的地的放在前面。
上个小栗子:
小注意点
1、目的地的空间必须足够大,否则会报错的。
2、\0仍然时操作停止的标准,在源头中拷贝到\0为止。并且\0也会拷贝上去,要不然例子中第一个字符串打印的就是 abcdefghtttttt 哦。
3、目的地必须是可被修改的空间,至于源头则没有要求。
简单实现(strcpy)
简单实现
思路就是拿过来两块空间,把一个空间的字符一个一个的复制到另一块空间上去(在代码里就是赋值)直到遇见\0这位刺头就停下,但他再刺头,也得把他也复制过去,毕竟有他字符串才完整么。
上代码:
#include<stdio.h>
#include<assert.h>
char* my_strcpy(char* dest, const char* scr)
{
//将scr接收时改为const常变量,也是为了保险,
//防止万一修改了源头中的字符串,毕竟我们只是要拷贝字符串。
assert(dest);//断言,防止传过来的是空指针。
assert(scr);
if (!*scr)//当源头中为空字符串时返回空指针。
{ //毕竟也没有拷贝的意义,直接赋值就得了呗。
return NULL;
}
char* ret = dest;//记录下目的地首元素地址,
//因为在拷贝的过程中会更改dest的所指向的地址的位置。
while (*dest++ = *scr++)//一个赋值表达式的最终的结果就所赋的那个值,
//这个很巧妙的就恰好在\0出停止,并且还将\0也拷贝过去了。
{
;
}
return ret;
}
int main()
{
char arr1[] = "iloveyou";
char arr2[20] = { 0 };
char* pstr = my_strcpy(arr2, arr1);
printf("%s\n", pstr);
return 0;
}
结果配图:
库函数的实现
嗯·······着实抱歉没有找到啊,其实关于stercpy源码的文章也不少,感兴趣完全可以去找找 。
strncpy
用法简介
仔细看一看哦,它跟strcpy的不同在哪里?就差在了这个 n ,
char* strcnpy(char* dest,char* src,size_t num)
源头
目的地
num --- 你要拷贝的字符的个数
这个num一下就让它的功能强大不少吧。他俩最大的区别就是strncpy可以自定义拷贝的字符个数,而strcpy则不能。
来个离子:
小注意
1、再拷贝完要求的字符数目后,仍然会补上一个\0,以表示我还是操作字符串的函数。
2、源头字符串的字符个数比要求的个数少时,以\0充数。
3、目的地的空间要足够大哦。
简单实现
这就偷个懒了,可能有点挫,见谅。
char* my_strncpy(char* dest, const char* scr,size_t num)
{
assert(dest);
assert(scr);
if (!*scr)
{
return NULL;
}
char* ret = dest;
int i = 0;
for (i = 0; i < num; i++)
{
*dest = *scr;
dest++;
scr++;
}
*dest = '\0';
return ret;
}
int main()
{
char arr1[] = "iloveyou";
char arr2[20] = { 0 };
char* pstr = my_strncpy(arr2, arr1,5);
printf("%s\n", pstr);
return 0;
}
配张图:
完
怎么样?感觉不过如此吧。希望大佬们可以帮忙提一些建议。
好好学习,天天进步。
Thanks.
See you next time.