问题一:函数区别
memcpy与memmove都是对内存进行拷贝可以拷贝任何内容,而strcpy仅是对字符串进行操作。
memcpy与memmove拷贝多少是通过其第三个参数进行控制而strcpy是当拷贝至'\0'停止。
memmove函数的功能同memcpy基本一致,但是当src区域和dst内存区域重叠时,memcpy可能会出现错误,而memmove能正确进行拷贝。
问题二:memcpy效率
https://aigo.iteye.com/blog/2299702
https://blog.csdn.net/z2007b/article/details/6559457
待分析。
问题三:memcpy实现
实现memcpy:
实现一:
void *memcpy(void *dest, const void *src, size_t count)
{
assert(src != NULL && dest != NULL);
char *tmp = dest;
const char *s = src;
while (count--)
*tmp++ = *s++ ;
return dest;
}
实现二:
void * memcpy(void *dst,const void *src,size_t num)
{
assert(src != NULL && dest != NULL);
int nchunks = num/sizeof(dst); /*按CPU位宽拷贝*/
int slice = num%sizeof(dst); /*剩余的按字节拷贝*/
unsigned long * s = (unsigned long *)src;
unsigned long * d = (unsigned long *)dst;
while(nchunks--)
*d++ = *s++;
while (slice--)
*((char *)d++) =*((char *)s++);
return dst;
}
实现三(如果内存有重叠):
void *memcpy(void *dest, const void *src, size_t count)
{
assert(src != NULL && dest != NULL);
char *d;
const char *s;
if (dest > (src+size)) || (dest < src))
{
d = dest;
s = src;
while (count--)
*d++ = *s++;
}
else /* overlap */
{
d = (char *)(dest + count - 1); /* offset of pointer is from 0 */
s = (char *)(src + count -1);
while (count --)
*d-- = *s--;
}
return dest;
}