memcpy问题,如图,memcpy下一个复制的数据会覆盖掉原有数据,有没有啥方法可以把新的数据加到原有数据

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了memcpy问题,如图,memcpy下一个复制的数据会覆盖掉原有数据,有没有啥方法可以把新的数据加到原有数据相关的知识,希望对你有一定的参考价值。

前边,不覆盖掉原有数据,数据得兼容一切数据哦,不仅是字符,还得是任何2进制数据,谢谢

其实吧,建议查一下api,这个很容易查到的!!!后面一句解释是关键!!!

参考技术A #include <stdio.h>

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下一个复制的数据会覆盖掉原有数据,有没有啥方法可以把新的数据加到原有数据的主要内容,如果未能解决你的问题,请参考以下文章

strcpy和memcpy的区别

strcpy和memcpy的区别

memcpy 仅通过 C++ 复制一个字节

结构赋值还是memcpy? [复制]

memcpy 是可简单复制的类型构造还是赋值?

了解为啥它不能使用 memcpy 正确复制