memcpy函数的实现


大致一看题目,memcpy函数,多简单的,核心不就是*dst++ = *src++吗,稍微加个参数检测,搞定。其实不要小看这道题,学问大着呢。


要写好一个完整的memcpy至少要做到以下几点:

1.判断输入指针是否为NULL。(长度可判可不判,因为长度如果<0,后面代码也能处理)

2.考虑内存是否重叠问题。

内存是否重叠问题,即当dst是src的后半部分时,对dst的copy会导致原src后半部分被覆盖,后续的拷贝会出错。(其实linux低下memcpy本身是不处理这种情况的,memmove函数才会考虑内存重叠问题,所以用memcpy函数时,安全性要程序员来保证,参考:http://blog.csdn.net/ce123/article/details/9002276)。

内存重叠需倒序拷贝。

3.高效性。32位总线可以每次复制一个int,64位总线可以一次性复制long long。所以要分成int和char类型来处理,优先int型处理方式。不过要注意,倒序拷贝时,减1必须转化为int类型后减1,*(Int*)dst = *(int *)src填充的才是最后一个int。


代码如下:


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值