目录
八、strtok
一、strcpy
1、函数实现:
- 函数中需要传入俩个参数,被拷贝的字符串需要const修饰,防止被拷贝的目标函数被修改,在strcpy函数的需求中,并不需要修改原字符串,只需要将原字符串拷贝到另一个用于储存原字符串内容的数组中;
- 需要采用指针来访问俩个字符串,防止字符串首地址丢失;字符串都是以 ' \0 ' 结尾的,即为一串字符串结束的标志,所以在遍历字符串时,以 ' \0 ' 为结束标志;
- 在遍历结束目标字符串后,完成字符串的拷贝,但是字符串是以 ' \0 ' 为结束标志的,所以就需要将strDestination的指针pDest指向位置的值赋为 ' \0 ' ;
- 最后将存储strDestination原字符串内容的首地址返回;
2、 代码实现:
char* my_strcpy(char *strDestination, const char *strSource) {
if (strDestination == NULL || strSource == NULL) {
return strDestination;
}
char* pDest = strDestination;
//while (*strSource != '\0') {
// *pDest++ = *strSource++;
//}
while (*pDest++ = *strSource++);
//*pDest = '\0';
return strDestination;
}
3、实现过程中发现的问题:
- 在while循环中判断循环是否能继续循环的条件是满足括号中的条件,即括号中的判定为真,此外,在while循环中,也可以使用数值 0 或 1 判断,还有一个指针是否为空;
上述俩种方式都是可以终止while循环,但是在实现strcpy的过程中发现 ' \0 ' 也是可以终止while循环的,也就是说 ' \0 ' 也是可以看成 0 ;
- 在编写strcpy函数时,回顾了 i++ 与 ++i 的用法:在语句 while(*pDest++==*strSource++)中, ' * ' 与 ' ++ ' 的优先级是相同的,他们都属于单目运算符,但是 i++ 是先进行赋值 ,然后在进行 ++ ,所以在这条语句中,pDest 与 strSource 的运算顺序就是:
pDest == strSource -> pDest++ && strSource++ ;
也就是先进行判断在进行指针 pDest 和 指针 strSource 的向后移动的操作;
二、strncpy
1、函数实现
- strncpy函数在strcpy的基础上进行功能增强:将目标函数 len 个元素拷贝到dest;在输出结果上与strcpy略有不同——strcpy在拷贝目标函数,若src长度小于dest,输出dest时,dest未被覆盖的字符不做输出,即src中的 ' \0 ' 也被拷贝在dest中去,但是strncpy是将 len 个元素拷贝在dest中,如果src的长度大于len,将src的 len 个元素拷贝dest 中去但是 src 的长度大于 len 所以就不会访问到 src 的 ' \0 ' ,所以dest中的第 len 个元素之后未被覆盖的元素也会被输出,不会被 ' \0 ' 截断的;如果 len 大于 src 就会自动补全strlen(src) 位置后的 ' \0 ' ;
- 第一个while循环就是将src 的前 len个元素拷贝到dest中去;在第二个while循环中循环条件是判断count是否大于零,也就是判断 src 是否小于 len ,如果