请问一个 memcpy 的问题

#include
#include
#include
main()
{
char*src="abc123";
char*dest="test";//这样会发生segmentationfault(coredumped)
//chardest[10]="test";//success这样成功执行
//char*dest=strdup("test");//success这样成功执行
memcpy(dest,src,strlen(src)+1);
printf("%s\n",dest);
}
//关于memcpy复制字符串时,memcpy(dest,src,strlen(src)+1),目标字符串dest类型char*xxx,charxxx[]有什么不同,char*会发生segmentationfault(coredumped),而charxxx[]不会,但strdup后的char*就能成功执行。
大话西游666
浏览 492回答 2
2回答

慕的地6264312

char*x="xyz";的标准写法是constchar*x="xyz";,通常用来表示「字符串字面量」,即编译器会把这个字符串放到常量区,因此向其中写入数据会发生错误。char[]是一个数组,被置于自动变量区,因此可以改变它的值。strdup会用malloc申请一段内存,并将参数复制进去,因此这个变量位于堆内存上,也是可写的。其实在后两句中,会「隐式」地创建一个「字符串字面量」,然后将它复制到一段可写内存上。

慕村9548890

char*dest="test";在一些编译器编译后分配的是只读空间是一个原因,另一个很显而易见,但是楼上没有人说,我补充一下。"test"一共分配5个字节的内存。你往里面copy的"abc123"长度是7个,显然越界了嘛,你在什么编译器下面编译都会发生segmentationfault(coredumped)的。简单的这样写很糟糕memcpy(dest,src,strlen(src)+1);这就是万恶之源,不搞清内存大小后面会带来无尽的痛苦的。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript