天天看点

C语言-字符串函数的实现(二)之strcpy

C语言中的字符串函数有如下这些

  • 获取字符串长度
    • strlen
  • 长度不受限制的字符串函数
    • strcpy
    • strcat
    • strcmp
  • 长度受限制的字符串函数
    • strncpy
    • strncat
    • strncmp
  • 字符串查找
    • strstr
    • strtok
  • 错误信息报告
    • strerror

接下来看看如何实现它们

我们看看文档是怎样说的,如下

strcpy文档

char * strcpy ( char * destination, const char * source );      

Copy string

字符串拷贝(字符串复制)

Copies the C string pointed by source into the array pointed by destination, including the terminating null character (and stopping at that point).

复制由字符指针source指向的C字符串到另一个字符数组中,该字符数组由字符指针destination指向

To avoid overflows, the size of the array pointed by destination shall be long enough to contain the same C string as source (including the terminating null character), and should not overlap in memory with source.

为避免溢出,由destination指向的字符数组的大小需要足够长,足够包含住源字符串(包含'\0')

综上,可以知道

  1. 会将源字符串中的 '\0' 拷贝到目标空间,源字符串必须以 '\0' 结束。
  2. 目标空间必须足够大,以确保能存放源字符串。

怎么实现拷贝?

int main() 
{
	char arr1[] = "abcdefghi";
	char arr2[] = "bit";
	// 把arr2的内容拷贝到arr1中
	//strcpy(arr1, arr2);
	// 怎么拷贝?

	my_strcpy(arr1, arr2);
	printf("%s\n", arr1);
	return 0;
}      

实现

断言指针不为空是个好习惯~
//char* my_strcpy(char* dest, char* src) 
// src加上const,为什么?因为我们只需要拷贝,不需要改动源字符串,防止发生修改,所以加上const修饰
char* my_strcpy(char* dest, const char* src) 
{
	assert(dest != NULL);
	assert(src != NULL);

	while (*src != '\0') 
	{
		*dest = *src;
		dest++;
		src++;
	}
	*dest = *src;	// '\0'
    // 返回目的空间的起始地址
    return dest;
}      
char* my_strcpy(char* dest, const char* src) 
{
	assert(dest != NULL);
	assert(src != NULL);
	// 优化
	while (*src != '\0')
	{
		*dest++ = *src++;
	}
	*dest = *src;	// '\0'
    // 返回目的空间的起始地址
    return dest;
}      
char* my_strcpy(char* dest, const char* src) 
{
	assert(dest != NULL);
	assert(src != NULL);
	// 优化
	// 拷贝src指向的字符串到dest指向的空间,包含'\0'
	char* rest = dest;
	while (*dest++ = *src++)
	{
		;
	}
	// 返回目的空间的起始地址
	return rest;
}      

继续阅读