这两个函数是整形数组里的库函数
一、memcpy–类型不限
函数简介
数memcy从source的位置开始向后复制num个字 节的数据到destination的内存位置。
●这个函数在遇到’\0’的时候并不会停下来。
●如果source和destination有 任何的重叠, 复制的结果都是未定义的。
memcpy(arr1, arr2);//函数名(目的地,源头,num)num要拷贝多少字节
函数实现
void* my_memcpy(void* dest, const void* src, size_t num)
{
void* ret = dest;
while (num--){
*(char*)dest = *(char*)src;//强制类型转换成位char类型一字节每次拷贝一个字节
++(char*)dest;
++(char*)src;
}
return ret;
}
二、memove函数
函数简介
void *memmove(void *str1, const void *str2, size_t n) 从 str2 复制 n 个字符到 str1,但是在重叠内存块这方面,memmove() 是比 memcpy() 更安全的方法。如果目标区域和源区域有重叠的话,memmove() 能够保证源串在被覆盖之前将重叠区域的字节拷贝到目标区域中,复制后源区域的内容会被更改。如果目标区域与源区域没有重叠,则和 memcpy() 函数功能相同。
原理相同的话,但拷贝的方法不同,一个是从前往后拷贝
而memove是还会根据数据的不同进行相应的判断,判断号拷贝的区域使用从前向后拷贝是否会出现
原有数据被覆盖或者丢失的情况
void* my_memove(void* dest, const void* src, size_t num)
{
void* ret = dest;
if (dest < src)
{ //从前向后面拷贝
while (num--) {
*(char*)dest = *(char*)src;//强制类型转换成位char类型一字节每次拷贝一个字节
++(char*)dest;
++(char*)src;
}
}
else//后-》前
{//以防数据重叠导致数据的丢失
*((char*)dest + num) = *((char*)src+ num);
}
return ret;
}
总结
库函数memcpy其实可以胜任自己拷贝自己的情况的,但是有些编译器不行,因为以C99的标准memcpy只需要完成拷贝工作即可但自己拷贝自己的时候,你得使用memove这个函数,才能完成这个工作