资源来源于cplusplus网站
它的作用是:
将数字字节的值从源指向的位置直接复制到目标指向的内存块。
源指针和目标指针指向的对象的基础类型与此函数无关; 结果是数据的二进制副本。
该函数不检查源代码中是否有任何终止空字符-它总是准确地复制 num 字节。
为了避免溢出,目标参数和源参数所指向的数组的大小应至少为 num 字节,并且不应该重叠(对于重叠的内存块,memmove 是一种更安全的方法)。
简化:内存复制,拷贝。
void * memcpy ( void * destination, const void * source, size_t num );
• 函数memcpy从source的位置开始向后复制num个字节的数据到destination指向的内存位置。
• 这个函数在遇到 ‘\0’ 的时候并不会停下来。
• 如果source和destination有任何的重叠,复制的结果都是未定义的。
#include
#include
int main()
{
int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };
int arr2[10] = { 0 };
memcpy(arr2, arr1, 20);
int i = 0;
for (i = 0; i < 10; i++)
{
printf("%d ", arr2[i]);
}
return 0;
}
//不建议这样写
void* my_memcpy(void* dest, const void* src, size_t num)
{
void* ret = dest;
assert(dest && src);
while (num--)
{
//拷贝一个字节
*(char*)dest = *(char*)src;
++(char*)dest;
++(char*)src;//存在一定的风险(有一些编译器不支持这种写法)
}
return ret;
}
//推荐写法
void* my_memcpy(void* dest, const void* src, size_t num)
{
void* ret = dest;
assert(dest && src);
while (num--)
{
//拷贝一个字节
*(char*)dest = *(char*)src;//该处的强制转换是临时的
dest = (char*)dest + 1;//该处需要再次强制转换
src = (char*)src + 1;//转换后不能直接++,例如(char*)dest++
}
return ret;
}
int main()
{
int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };
int arr2[10] = {0};
my_memcpy(arr2, arr1, 20);
int i = 0;
for (i = 0; i < 10; i++)
{
printf("%d ", arr2[i]);
}
return 0;
}