本文主要是介绍C语言第五十七弹---模拟使用memmove函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
使用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;
}
这篇关于C语言第五十七弹---模拟使用memmove函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!