模拟实现strcpy:
(1)字符串拷贝函数就是将原串拷贝到新串,而原串无需变换,可以用const来修饰。包括‘\0’全部拷贝到新的子串dest。
(2)while ((*dest++ = *src++) )
{
;
}
这种遍历程序连同‘\0’一起拷贝了while ((*dest++ = *src++) )相当于while ((*dest++ = *src++) !=‘\0’),上一次拷贝到最后一个字符时后置加加,将src变为‘\0’了,而下次再进入while循环时先执行*dest++ = *src++,dest也拷贝为‘\0’.而此时不满足该条件跳出while循环。但是此时已经拷贝了'\0'了。这也是程序的先后性。
或者可以:while (*src)
{
*dest = *src;
dest++;
src++;
}
原串为‘\0’时跳出,并未拷贝‘\0’,要赋值*dest = '\0',需要赋值 *dest = '\0'。
其实对于以上两种方法均可都执行*dest = '\0'操作,即使赋值过再赋值也无妨。
(3)另外要说的一点是:自加有副作用,因此return dest 可能读到最后'\0'就不输出了。因此需要定义新变量来保存首地址
char *ret = dest以便返回。
代码如下:
#include<stdio.h> #include<stdlib.h> #include<assert.h> char* my_strcpy(char* dest, const char* src) //const使在函数中不能修改*src原先的值 { assert(dest); //两次断言-->检验参数,增加代码健壮性 assert(src); char* strdest = dest; //保存原始指针地址 while (*src) { *dest++ = *src++; } *dest = '\0'; return strdest; } int main() { char arr1[] = "hello world!"; char arr2[20] ; char* ret = my_strcpy(arr2, arr1); printf("%s", ret); system("pause"); return 0; }