使用C语言模拟使用memmove函数
memmove是一个C语言库函数,用于在内存中移动一块数据。它可以在源地址和目标地址之间复制任意大小的数据块,并且会处理重叠的情况。即使源和目标是重叠的,memmove函数也可以确保数据被正确复制。
源定义
void* memmove(void* dest, const void* src, size_t n);
dest是指向目标位置的指针,src是指向源位置的指针,n是要复制的字节数。
memmove函数主要用于移动内存中的数据,而不是简单地复制。它会确保数据在移动过程中的正确性,即使源地址和目标地址有重叠的部分也不会出错。
和memcpy的差别就是memmove函数处理的源内存块和⽬标内存块是可以重叠的。如果源空间和⽬标空间出现重叠,就得使⽤memmove函数处理。
思路:若dest在src的右边,即dest < src,则使用循环逐个字节地将源地址的数据复制到目标地址。在每次循环迭代中,将src和dest指针强制转换为char*类型,以便每次复制一个字节。
若dest在src的左边,即dest >= src,则从后向前逐个字节地将源地址的数据复制到目标地址。此时,使用num–作为偏移量,以实现逆序复制。同样,也是每次复制一个字节。
代码如下:
void* my_memmove(void* dest, const void* src, size_t num) { assert(dest && src);//断言 void* ret = dest; if (dest < src)//dest在src右边 { while (num--) { *(char*)dest = *(char*)src; dest = (char*)dest + 1; src = (char*)src + 1; } } else//dest在src左边 { while (num--) { *((char*)dest + num) = *((char*)src + num);//从后往前拷贝 num--故不用dest src--; } } return ret; } int main() { int arr1[] = { 1,2,3,4,5,6,7,8,9,10 }; my_memmove(arr1 + 5, arr1, 20); int sz = sizeof(arr1) / sizeof(arr1[0]); for (int i = 0; i < sz; i++) { printf("%d ", arr1[i]); } return 0; }