🌞各位看官:欢迎来到(每日小知识)
🌟建议订阅专栏--> 每日小知识
🌟也欢迎关注小编--> 小峰同学
赶快上🚌跟着小编每天进步一点点,开心学习每一天。
😘如果觉得小编的文章对你有帮助,可以一键三连支持小编
😍你的支持才是小编最大的动力
👻本期重点:讲解memcpy和memmove的详解以及区别。
1,memcpy
内存复制。
void * memcpy ( void * dest, const void * src, size_t num );
//和strncpy很相似。但是void*不同。
//num单位是字节,就是复制多少字节过去。
//dest就是目标空间的起始地址。src是源空间的起始地址。
//返回的是一个地址void*类型的地址。
注意:
- 函数memcpy从src的位置开始向后复制num个字节的数据到dest的内存位置。
- 这个函数在遇到 '\0' 的时候并不会停下来。
- 如果src和dest有任何的重叠,复制的结果都是未定义的。
- 拷贝的时候应该是不重叠的拷贝。
举例:
int main()
{
int arr1[10] = { 0,1,2,3,4,5,6,7,8,9 };
int arr2[5];
memcpy(arr2, arr1, sizeof(arr1[0]) * 5);
for (int i = 0; i < 5; i++)
{
printf("%d", arr2[i]);
}
//结果为:01234
return 0;
}
模拟实现:
void* memcpy(void* dest, const void* src, size_t count)
{
assert(dest && src);
void* mid = dest;
//for (int i = 0; i < count; i++)
//{
// *(char*)dest = *(char*)src;
// dest = (char*)dest + 1;
// //dest++;
// src = (char*)src + 1;
// //src++;
//}
while (count--)
{
*(char*)dest = *(char*)src;
((char*)dest)++;
((char*)src)++;
}
return mid;
}
//注意强制类型转换,不是永久性的转换。
注意:这个代码还是有一定问题的。这个只是模拟实现的。在重叠内存拷贝的时候是未定义的。虽然vs这个编译器是可以实现重叠内存拷贝但是,不能保证任何环境下都能重叠拷贝。C语言的语法未规定,memcpy是否可以重叠拷贝。
2, memmove
重叠内存拷贝。
void * memmove ( void* dest, const void * src, size_t num );
//参数和memcpy一样。
注意:
- 和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的。C语言规定memmove可以重叠拷贝。
- 如果源空间和目标空间出现重叠,就得使用memmove函数处理。
模拟实现:
void* my_memmove(void* dest, const void* src, size_t count)
{
char* mid = dest;
if (dest < src)
{
//前->后
while (count--)
{
*(char*)dest = *(char*)src;
dest = (char*)dest + 1;
src = (char*)src + 1;
}
}
else
{
//后->前
while (count--)
{
//
//dest = (char*)dest + count;
//src = (char*)src + count;
//*(char*)dest = *(char*)src;//这个是错误代码。
*((char*)dest + count) = *((char*)src + count);
}
}
return mid;
}
各位看官今天就讲到这里了。。多谢观看。