strcpy提供了字符串的复制。即strcpy只用于字符串复制,并且它还会复制字符串的结束符。
已知strcpy函数的原型是:char* strcpy(char* dest, const char* src);
memcpy提供了一般内存的复制。即memcpy对于需要复制的内容没有限制,因此用途更广。
void *memcpy( void *dest, const void *src, size_t count );
从以上两个函数的参数类型和返回类型,可以看出两个函数的第一个不同点:
a、 strcpy只能应用字符类型的复制,而memcpy应用范围更广,例如字符数组、整型、结构体、类等。;
b、复制的方法不同。strcpy不需要指定长度,它遇到被复制字符的串结束符"\0"才结束,所以容易溢出。memcpy则是根据其第3个参数决定复制的长度。 memcpy相比使用strcpy会更加的安全,当然也可以使用strcpy的安全板本strncpy函数;
char * strcpy(char *dst,const char *src) //[1]
{
assert(dst);
assert(src); //[2]
char *ret = dst; //[3]
while ((*dst++=*src++)!='\0'); //[4]
return ret;
}
ps:不过似乎memcpy没考虑内存覆盖的问题,memmove才有考虑
void * my_memcpy(void *dst,const void *src,unsigned int count)
{
assert(dst);
assert(src);
void * ret = dst;
//重叠但不影响复制或者源地址和目的地址不重叠,低字节向高字节拷贝
if (dst <= src || (char *)dst >= ((char *)src + count))
{
while(count--)
{
*(char *)dst = *(char *)src;
dst = (char *)dst + 1;
src = (char *)src + 1;
}
}
else //源地址和目的地址重叠,高字节向低字节拷贝
{
dst = (char *)dst + count - 1;
src = (char *)src + count - 1;
while(count--)
{
*(char *)dst = *(char *)src;
dst = (char *)dst - 1;
src = (char *)src - 1;
}
}
return ret;
}