模拟实现memmove函数

完成这道题目之前首先要明确memmove是对内存进行操作,所以函数的参数是void *,即可以操作任意类型的数据。

其次要明白两个待处理数据的关系,于是我画了一张图帮助大家理解
模拟实现memmove函数
上面的是特殊情况,发生内存重叠时只有这种情况是需要从右向左进行操作的,如果这种情况还是按照从左往右操作的话就会把想要拷贝的东西一直重复的拷贝下去,除这种情况之外都只需从左往右拷贝

再然后就是如何实现代码的过程了,其方法和之前说过的拷贝函数类似,进行值的交换,在这里就不详细赘述了。

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<windows.h>
void my_memmove(void dst,const void src, int num)
{
void
ret = dst;
if (dst > src&&(char )dst <((char ) src + num))//dst包含于src的情况,从后往前进行操作
{
dst = (char )dst + num - 1;//将dst指向最后一个元素
src = (char
)src + num - 1;
while (num--)
{
(char)dst = (char)src;
dst=(char )dst-1;
src=(char
)src-1;
}
}
else
{
while (num--)
{
(char)dst = (char)src;
dst = (char )dst + 1;
src = (char
)src + 1;
}
}
return (ret);
}
int main()
{
char dst[100] = "hello world";

my_memmove(dst + 1, dst, strlen(dst) + 1);
printf("%s",dst);
system("pause");
return 0;

}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章