void *memmove(void *dest, const void *source, size_t count)
{
assert((NULL != dest) && (NULL != source));
char *tmp_source, *tmp_dest;
tmp_source = (char *)source;
tmp_dest = (char *)dest;
if((dest + count<source) || (source + count) <dest))
{// 如果没有重叠区域
while(count--)
*tmp_dest++ = *tmp_source++;
}
else
{ //如果有重叠
tmp_source += count - 1;
tmp_dest += count - 1;
while(count--)
*--tmp_dest = *--tmp;
}
return dest;
}
void *memcpy(void *dest, const void *source, size_t count)
{
assert((NULL != dest) && (NULL != source));
char *tmp_dest = (char *)dest;
char *tmp_source = (char *)source;
while(count --)//不对是否存在重叠区域进行判断
*tmp_dest ++ = *tmp_source ++;
return dest;
}menmove和memcpy的实现
最新推荐文章于 2024-08-08 11:06:37 发布
本文详细解析了memmove和memcpy两个内存操作函数的实现原理。memmove能够处理源和目标区域重叠的情况,而memcpy则假定两者不重叠。通过对源码的逐行解读,帮助读者理解这两个函数在不同情况下的行为。
1173

被折叠的 条评论
为什么被折叠?



