函数原型
void *memcpy(void*dest, const void *src, size_t n);
功能
由src指向地址为起始地址的连续n个字节的数据复制到以destin指向地址为起始地址的空间内。
头文件
C语言中使用#include 《string.h》;
C++中使用#include 《cstring》和#include 《string.h》都可以
返回值
函数返回指向dest的指针。
说明
1.source和destin所指内存区域不能重叠,函数返回指向destin的指针。
2.与strcpy相比,memcpy并不是遇到'\0'就结束,而是一定会拷贝完n个字节。
memcpy用来做内存拷贝,你可以拿它拷贝任何数据类型的对象,可以指定拷贝的数据长度;注意,source和destin都不一定是数组,任意的可读写的空间均可。
例:
char a[100], b[50];
memcpy(b, a,sizeof(b)); //注意如用sizeof(a),会造成b的内存地址溢出。
strcpy就只能拷贝字符串了,它遇到'\0'就结束拷贝;
例:
char a[100], b[50];
strcpy(a,b);
3.如果目标数组destin本身已有数据,执行memcpy()后,将覆盖原有数据(最多覆盖n)。如果要追加数据,则每次执行memcpy后,要将目标数组地址增加到你要追加数据的地址。
4.注意最后一个参数size_t n;
例:
int a[10] = {0,1,2,3,4,5,6,7,8,9};
memcpy(a, a + 3, 2);
你猜拷贝过之后a数组的值是什么?
3,4,2,3,4,5,6,7,8,9,
错!!!
真实结果是:
3,1,2,3,4,5,6,7,8,9,
为什么?
因为memcpy的最后一个参数是需要拷贝的字节的数目!一个int类型占据4个字节!这样的话,要想达到将a+3地址开始的2个元素拷贝到a地址处,需要这么写:
memcpy(a, a + 3, 2*sizeof(int));
经过这么一条语句,a数组的内容就变成了:
3,4,2,3,4,5,6,7,8,9,
这才是我们想要的!
下面是一些实例↓
实例1: 将字符串复制到数组 dest 中
运行结果:dest = http://www.runoob.com
实例2: 将 s 中第 11 个字符开始的 6个连续字符复制到 d 中:
运行结果:runoob
实例3: 覆盖原有部分数据:
运行结果:使用 memcpy 前: abcdefg
使用 memcpy 后: ***defg
愿你出走半生,归来仍是少年…