void* memmove( void* dest,const void* src,size_t num);
当源头和目的地有重叠时,其内容的拷贝就需要分情况进行讨论,然后采用不同的拷贝方式以达到目的:根据实际情况,具体可分为2类
1.目的地的起始地址dest<源头内容的起始地址src
目的地的起始地址(char*)dest>源头内容的起始地址(char*)src+num
进行拷贝时源内容从前向后每次拷贝一个字节,共拷贝num个字节即可完成要求大小的内容的拷贝
2.当(char*)src<=(char*)dest<=(char*)src+num
进行拷贝时源内容从后向前每次拷贝一个字节,共拷贝num个字节即可完成要求大小的内容的拷贝
#include<stdio.h>
#include<assert.h>
void* my_memmove(void* dest,const void* src,int num)//将arr2的内容拷贝到arr1中,拷贝num个字节
{//void类型的指针可以接收任意类型的数据的地址
assert(dest != NULL);
assert(src != NULL);//确保指针的有效性
void* ret = dest;//记录要返回的目的字符串的起始地址
if((dest<src)||((char*)dest>(char*)src+num))//满足条件的情况从前向后拷贝即可
{
while (num--)//一个字节一个字节的进行拷贝
{
*(char*)dest = *(char*)src;
++(char*)dest;
++(char*)src;
}
return ret;//返回目的字符串的起始地址
}
else
{
while (num--)
{
*((char*)dest + num) = *((char*)src + num);//从后向前依次拷贝
}
return ret;
}
}
int main()
{
int i = 0;
int arr1[] = { 1,2,3,4,5,6 };
my_memmove(arr1+2, arr1, 4*sizeof(arr1[0]));
for (i = 0; i < 6; i++)
{
printf("%d ", arr1[i]);
}
return 0;
}