库函数memcpy是内存函数的拷贝,memcpy的函数参数如下
把源头的指针的值拷贝到目标指针的值中,拷贝是按字节拷贝的,使用方法如下
#include<stdio.h>
#include<string.h>
int main(){int arr1[]={1,2,3,4,5,6,7,8,9,10};int arr2[10]={0};memcpy(arr2,arr1,20);//把arr1中20个字节的内容拷贝到arr2中return 0;
}
模拟实现一下这个库函数
#include<stdio.h>
void* my_memcpy(void* dest,const void* src,size_t num){assert(src&&dest);void* ret=dest;while(num--){*(char*)dest=*(char*)src;dest=(char*)dest+1;src=(char*)src+1;}
}
int main(){int arr1[]={1,2,3,4,5,6,7,8,9,10};int arr2[10]={0};my_memcpy(arr2,arr1,20);//把arr1中20个字节的内容拷贝到arr2中return 0;
}
这里就简单实现了,那么考虑一下,把1,2,3,4,5拷贝到3,4,5,6,7上面呢,如果还用刚刚实现的模拟函数会出现什么问题呢
根据这个运行结果发现,好像根本没拷贝过去,变成了不是我期望的值,这是为什么呢,仔细观察发现,向这种情况不能在从前向后拷贝了,应该是从后往前拷贝,但src<=dest都可以考虑是从后往前拷贝,当src>dest时可以从前往后拷贝,代码如下所示
#include<stdio.h>
void* my_memcpy(void* dest,const void* src,size_t num){assert(src&&dest);void* ret=dest;if(dest<src){while(num--){*(char*)dest=*(char*)src;dest=(char*)dest+1;src=(char*)src+1;}}else{while(num--){*((char*)dest+num)=*((char*)src+num);}}}
int main(){int arr1[]={1,2,3,4,5,6,7,8,9,10};int arr2[10]={0};my_memcpy(arr2,arr1,20);//把arr1中20个字节的内容拷贝到arr2中return 0;
}
虽然在刚刚的代码中实现了重叠部分的内存拷贝,但是在C语言的标准规定中,memcpy是实现不重叠的内存拷贝,memove是实现重叠部分的内存拷贝,要在适当的场景下使用不同的库函数。