模拟实现strcpy函数功能(优化改进)

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* 返回值,可以进行链式调用。

猜你喜欢

转载自blog.csdn.net/Watery________1314/article/details/83280368
今日推荐