strcpy函数,字符串拷贝函数,传入两个参数,将第二个参数的值拷贝到第一个中去。
首先,给出一个普通的代码:
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
void my_strcpy(char *str1, char *str2)
{
while (*str2)
{
*str1 = *str2;
str1++;
str2++;
}
*str1 = *str2;
}
int main()
{
char *p = "hello world!";
char arr[20] = { 0 };
my_strcpy(arr, p);
printf("%s\n", arr);
system("pause");
return 0;
}
这个代码通过判断*str2是否为'\0',进行循环,当没遇到'\0'时,将*str2一直拷贝到*str1,遇到'\0'时,跳出循环,但是还未将'\0'拷贝过去,所以循环外又加了一句将'\0'拷贝过去。
这个代码很容易理解,但是却不够完美,那么再对这个函数进行优化改进,如下代码:
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
char* my_strcpy(char *str1,const char *str2)
{
char *ret = str1;
assert(str1 != NULL);//断言
assert(str2 != NULL);
while (*str1++ = *str2++)
{
;
}
return ret;
}
int main()
{
char *p = "hello world!";
char arr[20] = { 0 };
my_strcpy(arr, p);
printf("%s\n", arr);
system("pause");
return 0;
}
优化1:我们将判断中的语句和判断外的语句成功融合,写成了一句代码。不管是不是'\0',先将值拷贝过去,再进行判断是否 为'\0',是'\0'跳出循环。
优化2:使用了assert函数,这个函数是断言函数,当其中一个字符串为NULL时,不满足程序出错,这时会提示,可以很好的找 到错误的位置。使用此函数注意调用头文件<assert.h>。
优化3:在第二个形参前加了const,当不小心将赋值写反了,写成把*str1拷贝到*str2时,因为*str2时const修饰的,所以*str2不 能修改,这时就会编译出错,避免出现运行出错难以寻找错误的问题。
优化4:定义了char* 返回值,可以进行链式调用。