⚠️注:重点介绍 memcpy ,memmove 函数。
话不多说,正文开始🔰
memcpy 与 memmove函数
传参和返回
观察发现,这两个函数的参数和返回类型一样,是否会觉得这两个函数有什么联系呢?
请看下文
memmove 函数实现
void* my_memmove(void* dest,const void* src, size_t count)
{
assert(dest && src);
int i = 0;
if(dest > src)//dest指向位置比src指向位置靠后
while (count--)//从后往前拷贝
{
*((char*)dest + count) = *((char*)src + count);
}
else
{
while (i != count)//从前往后拷贝
{
*((char*)dest + i) = *((char*)src + i);
i++;
}
}
return (char*)dest;
}
memcpy 函数实现
void* my_memcpy(void* dest, const void* src, size_t count)
{
assert(src && dest);
while (count--)
{
*((char*)dest + count) = *((char*)src + count);
}
return dest;
}
运行结果
这里可以看到其实两种函数的结果并不一样。,发现strcpy不能拷贝部分 重叠内存 情况
但是,在VS2019编译器中,库函数 memcpy 和 memmove 的功能一样强大,所以用VS编译器就会导致两个结果一样,然而其他的编译器不一定会让 memcpy 变得这样强大。
void* 为什么要强制类型转化为 char* ?
- 首先void*类型的变量是不能被赋值的
- 其次转化为char* 可以精确改变每个字节的内存(因为char是一个字节,类型改变的是指针的步长)。从而达到改变一个整型。
- 若是改变成其他大的类型容易造成内存的浪费。而且可以兼容所有类型的内存的改变。