字符串拷贝函数:strcpy的详解及模拟实现

举报
念君思宁 发表于 2023/02/13 21:45:23 2023/02/13
【摘要】 字符串拷贝函数:strcpy的详解及模拟实现

字符串拷贝函数:strcpy的详解及模拟实现!!!

对于字符串拷贝函数,之前在学习字符串时候,就已经学习过,但那只是片面的学习了一下,并没有经过系统的分析!只是大概的学习了一下!在关键的地方有时候还不知道该怎么用!所以出现学习跟没有学一样的效率!因此,笔者最近再次系统的学习了一下:所以才打算发一篇文章:  字符串拷贝函数:strcpy的详解及模拟实现 !来与大家共勉!

首先对于字符串拷贝函数:strcpy 我们需要知道:

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

上述的代码是指:在strcpy函数使用的时候,需要注意的格式问题!!对于destination 是指 :目的地  ,  source  是指:源头!!该片段的总体意思是:将源头拷贝到目的地!

对于本文的学习之前,需要知道一下知识储备!:

1.源字符串必须以'\0'结尾!

2.strcpy字符串拷贝函数:会将源字符串中的'\0'拷贝到目标空间!

3.目标空间必须足够大,以确保能存放源字符串!!

4.目标空间必须可变!(不能被const修饰)!

5.要学会strcpy字符串拷贝函数的模拟实现!

对于strcpy字符串拷贝函数!我们先做一下知识储备:

#include <stdio.h>
#include <string.h>
int main()
{
	char arr[10] = { 0 };
	const char* p = "abcdef";
	strcpy(arr, p);
	printf("%s\n", arr);
	return 0;
}

这段代码就是对于:strcpy字符串拷贝函数的简单实现!!想必大家也都能看懂!

代码的运行结果为:

 但是对于:const char* p = "abcdef";中的'\0'要不要拷贝到arr[10]里面去??心存疑惑!!

因此,我们可以将arr[10]数组进行初始化为:arr[10]="xxxxxxxxx"!!这样操作,加上调试,更能直观的看出来!

因此更改后的代码为:虽然结果也是一样的,但是在调试的过程中,可以显现出来:strcpy字符串拷贝函数:会将源字符串中的'\0'拷贝到目标空间!

 代码调试前的结果为:

请注意:arr[10]数组里面值的变化!

代码调试完成以后的结果为:

 综上代码的调试结果所述:strcpy字符串拷贝函数:会将源字符串中的'\0'拷贝到目标空间!

但是,在使用strcpy拷贝字符串中,必须要知道'\0‘所在的位置:因此,对于字符数组的拷贝就会出现问题!!请看下列代码::

#include <stdio.h>
#include <string.h>
int main()
{
	char arr[10] = "xxxxxxxxx";
	char arr2[] = { 'a','b','c' };
	strcpy(arr, arr2);
	printf("%s\n", arr);
	return 0;
}

 对于上述的代码中:由于在字符数组中:'\0'的位置并不知道,导致越界访问,所以会出现错误!!

请看代码的运行结果:

对于上述的出现错误的代码,笔者就不再进行调试了!请各位老铁可以理解一下!!

但是,当使用字符数组进行strcpy进行拷贝时候,手动放置一个'\0'!也可以进行正常的拷贝使用!!

 在这个代码中,拷贝的时候,也会将'\0'进行拷贝!!对于此问题,我们依然 可以通过调试来进行分析!

在调试完成之前的:

 调试完成之后:

在上述的调试结果中:我们可以清晰地看出来!在字符数组中,手动放置的'\0'也会进行拷贝!!

结合以往经验,笔者苦心专研了两个错误写法,下面请笔者……看一下代码:

1.目标空间必须足够大,以确保能存放源字符串!!否则,将会出现崩溃现象!!错误演示,请忽模仿

 
#include <stdio.h>
#include <string.h>
int main()
{
	char arr[3] = { 0 };
	char arr2[] = "abcdef";
	strcpy(arr, arr2);
	printf("%s\n", arr);
	return 0;
}

代码的运行结果为:

 程序崩溃!!

2.目标空间必须可变!(不能被const修饰,常量字符串不可被修改)!错误演示,请忽模仿

#include <stdio.h>
#include <string.h>
int main()
{
	char* p = "hello world";
	char arr2[] = "abcdef";
	strcpy(p, arr2);
	printf("%s\n", p);
	return 0;
}

该段代码的运行结果为:

 直接出现错误,不能被更改!!

上面两个是笔者之前专研的!!对于其他的bug若是读者有不同的想法,请私聊笔者哟!

下面笔者进行对strcpy字符串拷贝函数的模拟实现!!!也到了该拿出压箱底的实力了!!

请看笔者代码:

#include <stdio.h>
#include <string.h>
#include <assert.h>
 
char* my_strcpy(char* dest, const char* src)
{
	assert(dest);
	assert(src);
	char* ret = dest;
	while (*dest++ = *src++)
	{
		;
	}
	return ret;
}
 
int main()
{
	char arr1[20] = "abc";
	char arr2[] = "hello wang";
	my_strcpy(arr1, arr2);
	printf("%s\n", arr1);
	return 0;
}

对于上述代码中:

1.    assert(dest);   assert(src);  断言,因为在后面的文章中,对dest 与src都进行了解引用操作,所以在使用之前要确保不是空指针!!

2.在while循环里面,为什么是:*dest++ = *src++  而不是:*dest=*src;  dest++; src++;呢 ???其实主要的原因还是在于拷贝'\0'的问题,当while 循环里面判断出来是'\0'则会进行跳出,不会拷贝'\0';所以进行了上述while循环里面的操作!!实现先赋值在判断!!

3.为什么在最后的返回值是:return ret;????而不是 return  dest;??? 原因在于:随着dest++与src++的赋值,dest早已不再指向起始位置!!

代码的运行结果为:

 

上述就是笔者对该strcpy字符串拷贝函数的模拟实现的解析,若有不懂得老铁,请私聊笔者哟!!

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。