一.对库函数strcpy的了解
通过在MSDN或者cplusplus网站上检索strcpy
通过对strcpy的检索,可以初步了解到strcpy以下信息:
1.将源头得字符串复制到目标数组中
2.传入的参数只能是指针
3.连同 \0 一起会被复制到目标数组中
4.返回类型为char* 类型,即目标数组的地址
5.目标素组的内存大小应该要能放的小源头字符串并且不溢出
二.模拟实现库函数strcpy
#include<assert.h> #include<stdio.h> //将源头数据拷贝到目标数组,源头数据不可修改,用const限制 char* my_strcpy(char* dest, const char* soc) { assert(dest && soc);//断言dest和soc不是空指针 //记录目标数据得起始位置 char* p = dest; //将包括\0在内soc里得内容拷贝到dest里 while (*dest++ = *soc++) { ; } return p; //返回目标地址 } int main() { char arr1[50] = { 0 }; char arr2[] = "abcdef"; my_strcpy(arr2+1, arr2); printf("%s",arr2); return 0; }
三.strcpy的一些特殊情况
1.第一种情况
源头数据与目标数据内存重叠时(目标数据覆盖在源头数据里面)
#include<assert.h> #include<stdio.h> char* my_strcpy(char* dest, const char* soc) { assert(dest && soc); //记录目标数据得起始位置 char* p = dest; //将包括\0在内soc里得内容拷贝到dest里 while (*dest++ = *soc++) { ; } return p; //返回目标地址 } int main() { char arr1[50] = { 0 }; char arr2[10] = "abcd"; my_strcpy(arr2+2, arr2); printf("%s",arr2); return 0; }
运行结果如下:
通过分析,对于条件while(*dest++=*soc++),soc找不到 \0 复制给dest,导致条件无法停止下来。
不难发现,当目标内存和源头内存重叠的时候,程序无法进行,会直接崩溃掉
2.第二种情况
.目标数据与源头数据重叠时(源头数据覆盖在目标数据里面)
#include<assert.h> #include<stdio.h> char* my_strcpy(char* dest, const char* soc) { assert(dest && soc); //记录目标数据得起始位置 char* p = dest; //将包括\0在内soc里得内容拷贝到dest里 while (*dest++ = *soc++) { ; } return p; //返回目标地址 } int main() { char arr1[50] = { 0 }; char arr2[10] = "abcd"; my_strcpy(arr2, arr2+2); printf("%s",arr2); return 0; }
通过分析,预期结果为: c d
运行结果为:
不难发现,虽然目标数据与源头数据有重合,但是当源头数据覆盖在目标数据里面时, \0可以顺利被拷贝进去,可以正常运行并且实现
四.总结
1 .对于strcpy得模拟实现中,通过上述分析,只要源头数据能拷贝到 \0,即可。若要完成第一种情况,可以参考使用memmove这个库函数。
2.对于cpluscplus对于strcpy得定义中所说得内存中不应与源重叠为第一种情况,关于内存不应与源重叠得具体理解,可以参考另一篇文章–模拟实现库函数memmove