#include<stdio.h> void my_strcpy(char* dest,char* scr) { while(*scr!='\0') { *dest = *scr; dest++; scr++; } *dest = *scr;//'\0'的赋值 } int main() { char arr1[] = "****************" ; char arr2[] = "bit"; my_strcpy(arr1, arr2); printf("%s\n", arr1); return 0; }
初始代码,实现了想要的功能,但此时面试官最多给你6分,下面开始代码优化:
#include<stdio.h> void my_strcpy(char* dest,char* scr) { while(*dest++ = *scr++) { ; } } int main() { char arr1[] = "****************" ; char arr2[] = "bit"; my_strcpy(arr1, arr2); printf("%s\n", arr1); return 0; }
此时的代码已经进行了初步优化,但此时最多拿到7分,因为若出现下面的情况代码会出问题:
进一步优化代码:
此时,代码可以很好的运行,但是相当于避开了空指针,不利于程序员查错,故我们进一步优化:
#include<stdio.h> #include<assert.h> void my_strcpy(char* dest,char* scr) { assert(dest != NULL); assert(scr != NULL);//断言函数,若条件为真则顺序执行,条件为假则报错 while(*dest++ = *scr++) { ; } } int main() { char arr1[] = "****************" ; char arr2[] = "bit"; my_strcpy(arr1, NULL); printf("%s\n", arr1); return 0; }
程序执行结果:
此时,若arr2为空指针时,程序报错并指出错误所在位置,便于程序员发现错误,这时达到面试官心中的完美程序了吗?答案是否定的,此时的程序最多可以拿到8分,我们来看看C中原来的strcpy()函数是如何书写的呢?
为了很好的返回已经改变了的目的字符串,所以我们定义函数为char* ;为了防止传参过程中误将源字符串和目的字符串写反,我们引入const,使得源字符串为左值,不能更改,最终优化后的程序如下:
#include<stdio.h> #include<assert.h> char* my_strcpy(char* dest,const char* scr) { char* ret = dest; assert(dest != NULL); assert(scr != NULL);//断言函数,若条件为真则顺序执行,条件为假则报错 while(*dest++ = *scr++) { ; } return ret; } int main() { char arr1[] = "****************" ; char arr2[] = "bit"; printf("%s\n", my_strcpy(arr1, arr2) ); return 0; }
你学废了么?