memcpy的实现
通常来说,这个函数的实现比较简单
我看了下crt的实现源码,如下:(略去64位机的)
- C/C++ code
void * __cdecl memcpy ( void * dst, const void * src, size_t count ){ void * ret = dst; while (count--) { *(char *)dst = *(char *)src; dst = (char *)dst + 1; src = (char *)src + 1; } return(ret);}
今天,我看到一个面试题上叫实现这个函数,看了下它的参考答案,如下
- C/C++ code
void *MyMemCopy(void *dest,const void *src,size_t count){ char *pDest=static_cast<char *>(dest); const char *pSrc=static_cast<const char *>(src); //注意,这里是关键,为什么要这样比较呢?理由何在? if( pDest>pSrc && pDest<pSrc+count ) { for(size_t i=count-1; i<=0; ++i) { pDest[i]=pSrc[i]; } } else { for(size_t i=0; i<count; ++i) { pDest[i]=pSrc[i]; } } return pDest;}
大家讨论下吧~
[解决办法]
这个就是memcpy与memmove的区别
数据重叠区的处理!
楼主试试上面2个函数处理重叠数据区的copy
看了结果就知道为什么了!
[解决办法]
ctr的memset是不管区域重叠的,使用memmov则考虑区域重叠,更安全写
[解决办法]
[解决办法]
overleap
google memcpy memmove
[解决办法]
http://www.chinaitpower.com/A/2001-10-17/2036.html
[解决办法]
memcpy是把source 指向的对象中的n个字符拷贝到destin所指向的对象中,返回指向结果对象的指针。
[解决办法]
memcpy跟memmove的区别,memmove可以处理重叠的情况
[解决办法]
天哪, 这种"内存重叠"你也有办法判断出来?
[解决办法]
代码都已经说的很明白了吧。。。