标签:print printf char har 如何 return lse 重叠 com
完成这道题目之前首先要明确memmove是对内存进行操作,所以函数的参数是void *,即可以操作任意类型的数据。其次要明白两个待处理数据的关系,于是我画了一张图帮助大家理解
上面的是特殊情况,发生内存重叠时只有这种情况是需要从右向左进行操作的,如果这种情况还是按照从左往右操作的话就会把想要拷贝的东西一直重复的拷贝下去,除这种情况之外都只需从左往右拷贝
再然后就是如何实现代码的过程了,其方法和之前说过的拷贝函数类似,进行值的交换,在这里就不详细赘述了。
#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;
}
标签:print printf char har 如何 return lse 重叠 com
原文地址:https://blog.51cto.com/14239789/2399361