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; ?? ?} ?
?
?
|