/**
* @Method: Memcpy
* @Access: public
* @Return: void *
* @Param : dst - 目的起始地址
* @Param : src - 源起始地址
* @Param : len - 所要拷贝空间大小Byte
* @Brief : 内存拷贝,实现了内存重叠和非重叠的拷贝
* @Date : 2015-8-20 FengKang
*/
void *Memcpy(void *dst, const void *src, size_t len)
{
if(NULL == dst || NULL == src)
{
return NULL;
}
void *ret = dst;
if(dst <= src || (char *)dst >= (char *)src + len)
{
while(len--)
{
*(char *)dst = *(char *)src;
dst = (char *)dst + 1;
src = (char *)src + 1;
}
}
else
{
src = (char *)src + len - 1;
dst = (char *)dst + len - 1;
while(len--)
{
*(char *)dst = *(char *)src;
dst = (char *)dst - 1;
src = (char *)src - 1;
}
}
return ret;
}
1、 这里实现的Memcpy其实是C库中的memmove的实现。实际的memcpy是不考虑内存重叠这个问题的,也就是说使用memcpy时,dst和src的地址空间最好不要重叠。
C库中memcpy的实现:
void *memcpy(void *dst, const void *src, size_t len)
{
if(NULL == dst || NULL == src) return NULL;
void *ret = dst;
while(len--)
{
*(char *)dst = *(char *)src;
dst = (char *)dst + 1;
src = (char *)src + 1;
}
return ret;
}
2、说到memcpy那就不能不说strcpy了。已知strcpy函数的原型是:
char * strcpy(char * dstt,const char * src);
这里给出strcpy的一个可能实现(未考虑内存重叠)。如果要考虑内存重叠,可以像memmove一样采用逆序拷贝即可。
char *strcpy(char *dst, const char *src)
{
if(NULL == dst || NULL == src) return NULL;
char *ret = dst;
while((*(dst++) = *(src++)) != '\0'); // 默认拷贝最后的'\0'
return ret;
}
原文链接: https://www.cnblogs.com/fengkang1008/p/4746167.html
欢迎关注
微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍
原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/220845
非原创文章文中已经注明原地址,如有侵权,联系删除
关注公众号【高性能架构探索】,第一时间获取最新文章
转载文章受原作者版权保护。转载请注明原作者出处!