模拟实现strcpy(详解)

文章介绍了如何用C语言模拟实现库函数strcpy,通过断言确保指针非空,使用while循环逐个字符拷贝,包括结束标志,最后返回目标数组的地址。在main函数中,展示了使用自定义strcpy函数的例子。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言:内容包括:题目,代码实现,大致思路,代码解读

题目:

模拟实现库函数strcpy

代码实现:

#include<stdio.h>
#include<assert.h>
char* my_strcpy(char* dest, const char* src)
{
	//断言
	assert(dest && src);
	char* ret = dest;
	while (*dest++ = *src++)
	{
		;
	}
	return ret;
}

int main()
{
	char arr[] = "abcdef";
	char arr2[20] = { 0 };
	printf("%s", my_strcpy(arr2, arr));
	return 0;
}

大致思路:

1. 将字符串的所有字符(包括字符串的结束标志'\0')一个一个拷贝进arr2数组中

2. 使用两个指针:指针dest负责遍历arr2数组,指针src负责遍历arr数组

3. 为了防止传递的两个数组的地址是空指针,可以进行断言:使用assert

    为了防止原始数组中的内容被修改,可以使用const修饰

代码解读:

函数部分

#include<assert.h>
char* my_strcpy(char* dest, const char* src)
{
	//断言
	assert(dest && src);
	char* ret = dest;
	while (*dest++ = *src++)
	{
		;
	}
	return ret;
}

我们先了解库函数strcpy的语法:

 char *strcpy( char *to, const char *from );

功能:复制字符串from 中的字符到字符串to,包括空值结束符。返回值为指针to

1. 使用while循环将原始字符串中的每一个字符都拷贝到目标数组中

    这里运用两个指针:dest:指向目标数组,src:指向存储字符串的数组

*dest++ = *src++

字符的拷贝:当一个字符拷贝(对指针进行解引用操作)到目标数组中后,两个指针分别向后走,找到下一个要被拷贝的字符

当字符串的结束标志'\0'拷贝到目标数组中后,由于'\0'的ASCII码值为0,故而*dest++=*src++表达式的值变成0,为假,结束while循环

2.  返回目标数组的地址

由于dest指针是遍历目标数组的,故而当拷贝结束后,dest指针不再指向目标数组的首元素,故而我们在进行拷贝之前,需要将dest指针中存储的地址备份

主体部分

int main()
{
	char arr[] = "abcdef";
	char arr2[20] = { 0 };
	printf("%s", my_strcpy(arr2, arr));
	return 0;
}

my_strcpy数组的返回值(目标数组的地址)作为printf的参数,这里是链式访问

或者使用puts函数输出arr2数组中被拷贝过来的字符串