概述
一、memmove()和memcpy()函数和strcpy()函数的区别;
(1)使用的类型不同,strcpy()函数只对字符串进行操作;memmove()和memcpy()函数对所有类型都适用,为内存拷贝;
(2)strcpy()以’ ’为拷贝的结束条件;而memmove()和memcpy()函数则是以第三个参数num进行控制拷贝;
二、函数说明:
1.memcpy函数的功能是从源src所指的内存地址的起始位置开始拷贝N个字节到目标dst所指的内存地址的起始位置中。
2.memmove函数的功能同memcpy基本一致,但是当src区域和dst内存区域重叠时,memcpy可能会出现错误,而memmove能正确进行拷贝
三、memmove()和memcpy()函数的区别和联系:
相同点: 两个都是内存拷贝,对所有类型都适用;
不同点:
(1)memcpy()函数是从前往后拷贝;假入出现内存重叠的现象;拷贝结果可能出错;
(2)memmove()函数在memcpy()函数的基础上加入了对内存重叠拷贝的处理;引入了倒序拷贝的方式处理内存重叠的某些情况;保证拷贝的正确性;
综上:在现实中使用memmove()函数会比较好一点;
四、各种拷贝情况:
上述三种情况,memcpy可以成功对前两种进行拷贝,对第三种情况进行拷贝时,由于拷贝dst前两个字节时覆盖了src原来的内容,所以接下来的拷贝会出现错误。而memmove对第三种情况进行拷贝时会从src的最后向前拷贝N个字节,避免了覆盖原来内容的过程。
五、模拟实现:
memcpy:
//模式实现memcpy(不会解决内存重叠的问题,正序拷贝,适用于任何类型)
void* MyMemcpy(void* dest,const void* src,size_t num)
{
char* dest_tmp=(char*)dest;//目标字符串
const char* src_tmp=(const char*)src;//源字符串
assert(dest&&src);
while(num--)
{
*dest_tmp++= *src_tmp++;
}
return dest;
}
memmove:
//模拟实现memove(会解决内存重叠的问题,加上了逆序拷贝,适用于任何类型)
void* MyMemmove(void* dest,const void* src,size_t num)
{
char* dest_tmp=(char*)dest;
const char* src_tmp=(const char*)src;
assert(dest&&src);
if (src_tmp>dest_tmp || src_tmp+num<=dest_tmp)//情况1和情况2
{
while(num--)//正序复制
{
*dest_tmp++=*src_tmp++;
}
}
else//情况3,逆序赋值
{
//调整指针到最后
dest_tmp+=num-1;
src_tmp+=num-1;
while(num--)
{
*dest_tmp--=*src_tmp--;
}
}
return dest;
}
最后
以上就是飘逸八宝粥为你收集整理的memmove和memcpy函数的区别及实现的全部内容,希望文章能够帮你解决memmove和memcpy函数的区别及实现所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复