memcpy问题,如图,memcpy下一个复制的数据会覆盖掉原有数据,有没有啥方法可以把新的数据加到原有数据
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了memcpy问题,如图,memcpy下一个复制的数据会覆盖掉原有数据,有没有啥方法可以把新的数据加到原有数据相关的知识,希望对你有一定的参考价值。
前边,不覆盖掉原有数据,数据得兼容一切数据哦,不仅是字符,还得是任何2进制数据,谢谢
其实吧,建议查一下api,这个很容易查到的!!!后面一句解释是关键!!!
main()
char src[]="*******S";
char dest[200]="abcde"; // 这个数组要足够大
int i,k;
k = strlen(src);
memcpy(&dest[k],dest,strlen(dest)); // 老内容后移
memcpy(dest,src,k); //前面加新内容
printf("%s",dest); // 成功了
本回答被提问者和网友采纳
strcpy和memcpy的区别
strcpy和memcpy的区别
strcpy和memcpy都是标准C库函数,它们有下面的特点。 strcpy提供了字符串的复制。即strcpy只用于字符串复制,并且它不仅复制字符串内容之外,还会复制字符串的结束符。
已知strcpy函数的原型是:char* strcpy(char* dest, const char* src); memcpy提供了一般内存的复制。即memcpy对于需要复制的内容没有限制,因此用途更广。
char * strcpy(char * dest, const char * src) // 实现src到dest的复制 { if ((src == NULL) || (dest == NULL)) //判断参数src和dest的有效性 { return NULL; } char *strdest = dest; //保存目标字符串的首地址 while ((*strDest++ = *strSrc++)!=‘\0‘); //把src字符串的内容复制到dest下 return strdest; }
void *memcpy(void *memTo, const void *memFrom, size_t size) { if((memTo == NULL) || (memFrom == NULL)) //memTo和memFrom必须有效 return NULL; char *tempFrom = (char *)memFrom; //保存memFrom首地址 char *tempTo = (char *)memTo; //保存memTo首地址 while(size -- > 0) //循环size次,复制memFrom的值到memTo中 *tempTo++ = *tempFrom++ ; return memTo; }
strcpy和memcpy主要有以下3方面的区别。
1、复制的内容不同。strcpy只能复制字符串,而memcpy可以复制任意内容,例如字符数组、整型、结构体、类等。
2、复制的方法不同。strcpy不需要指定长度,它遇到被复制字符的串结束符"\0"才结束,所以容易溢出。memcpy则是根据其第3个参数决定复制的长度。
3、用途不同。通常在复制字符串时用strcpy,而需要复制其他类型数据时则一般用memcpy
简述strcpy与memcpy的相同点和区别点
相同点:strcpy与memcpy都可以实现拷贝的功能
不同点:
(1)实现功能不同,strcpy主要实现字符串变量间的拷贝,memcpy主要是内存块间的拷贝。
(2)操作对象不同,strcpy的操作对象是字符串,memcpy 的操作对象是内存地址,并不限于何种数据类型。
(3)执行效率不同,memcpy最高,strcpy次之。
以上是关于memcpy问题,如图,memcpy下一个复制的数据会覆盖掉原有数据,有没有啥方法可以把新的数据加到原有数据的主要内容,如果未能解决你的问题,请参考以下文章