strcpy和memcpy都是标准C库函数,它们有下面的特点。
strcpy提供了字符串的复制。即strcpy只用于字符串复制,并且它不仅复制字符串内容之外,还会复制字符串的结束符。
strcpy函数的原型是:
#include<string.h> char *strcpy(char *destination, const char *source);传回值是
destination
字符数组或是配置在存储器的字符指针(或是字符串指针)。使用方式与实现
char *str1 = malloc(LARGE_NUMBER); char *str2 = malloc(LARGE_NUMBER); fgets(str1, LARGE_NUMBER, stdin); strcpy(str2, str1); /* 這行程式碼類似 str2 "=" str1 */前两行程序码是先配置存储器,经由 malloc 函数把配置完成的存储器地址,传回给 str1 和 str2。到了下一行程序码,指向 str1 的存储器,会被用户输入的字符串填满。之后,复制 str1 字符串到 str2 的存储器区块内。虽然str2 = str1 这个程序叙述可以出现类似的现象,但是它只能复制地址从 str1 到 str2,让 str2 指向 str1 的存储器,实际上也无法真正做到复制字符串的动作。这就是 str1 和 str2 两个指针都指向相同的存储器区块地址。这相当于所谓的shallow copy(浅复制),因为 str2 实际上没有真正从 str1 复制到字符串,所以这两个指针所指的其实都是同一个的字符串。
char * strcpy(char * dest, const char * src) // 实现src到dest的复制
{
if ((src == NULL) || (dest == NULL)) //判断参数src和dest的有效性
{
return NULL;
}
char *strdest = dest; //保存目标字符串的首地址
while ((*strDest++ = *strSrc++)!='\0'); //把src字符串的内容复制到dest下
return strdest;
}
缓存溢出
必须注意使用 strcpy 函数,因为如果来源字符串的长度太长,当复制到目的缓冲器时,它会改写到连接目的缓冲器后方的存储器,导致无法预期的结果。而且程序通常容易会出现segmentation fault(区段错误,也就是常见的例外现象),但是熟练的黑客会利用缓存溢出来破解进入操作系统memcpy提供了一般内存的复制。即memcpy对于需要复制的内容没有限制,因此用途更广。
void *memcpy(void *memTo, const void *memFrom, size_t size)
{
if((memTo == NULL) || (memFrom == NULL)) //memTo和memFrom必须有效
return NULL;
char *tempFrom = (char *)memFrom; //保存memFrom首地址
char *tempTo = (char *)memTo; //保存memTo首地址
while(size -- > 0) //循环size次,复制memFrom的值到memTo中
*tempTo++ = *tempFrom++ ;
return memTo;
}
strcpy和memcpy主要有以下3方面的区别。1、复制的内容不同。strcpy只能复制字符串,而memcpy可以复制任意内容,例如字符数组、整型、结构体、类等。
2、复制的方法不同。strcpy不需要指定长度,它遇到被复制字符的串结束符"\0"才结束,所以容易溢出。memcpy则是根据其第3个参数决定复制的长度。
3、用途不同。通常在复制字符串时用strcpy,而需要复制其他类型数据时则一般用memcpy
参考资料
http://www.cnblogs.com/stoneJin/archive/2011/09/16/2179248.html
http://zh.wikipedia.org/zh-cn/Strcpy