原型声明:char *strcpy(char* str1, const char *str2);
功能:把从str2地址开始且含有'\0'结束符的字符串复制到以str1开始的地址空间
说明:str1和str2所指内存区域不可以重叠, 且str1必须有足够的空间来容纳src的字符串。
返回指向str1的指针。
strcpy( str1, str2);
str1的长度不够,会怎么样呢?
#include <iostream>
#include <cstring>
using namespace std;
int main()
{
char str1[3];
char *str2="abcdef";
strcpy(str1,str2);
cout<<str1<<endl;
}
输出abcdef
似乎拷贝成功,但这并不意味会自动把str1长度增加, 反而会把后面的其它数据破坏了
推荐使用strncpy
原型:char *strncpy(char *dest, char *src, int n);
用法:#include <cstring>
功能:把src所指由NULL结束的字符串的前n个字节复制到dest所指的数组中。
说明:如果src的前n个字节不含NULL字符,则结果不会以NULL字符结束。如果src的长度小于n个字节,则以NULL填充dest直到复制完n个字节。
strncpy(str1, str2, strlen(str1));第三个参数一定要小于等于第一个参数的实际长度,保证拷贝在str1自己的空间内,
但是,strlen(str1)并不一定就是缓冲区的实际长度,该函数测量到'\0'为止,如果str1第一个字节就是0,那么什么都拷贝不进去
这样就比较好感觉:
strncpy(str1, str2, sizeof(str1)/sizeof(char));
#include <iostream>
#include <cstring>
using namespace std;
int main()
{
char str1[3];
char *str2="ab";
strncpy(str1,str2,sizeof(str1)/sizeof(char));
cout<<str1<<endl;
}
同时,如果第二个串长度大于第三个参数,那么在str1不会以'\0'为结尾,生成的并不是有效字节串,会在一些使用中出错;应最后留一元素,手工写上 \0
如:
#include <iostream>
#include <cstring>
using namespace std;
int main()
{
char str1[3];
char *str2="abcd";
strncpy(str1,str2,sizeof(str1)/sizeof(char));
cout<<str1<<endl;
}
结果是错的呢
strlcpy(linux下)并不属于 ANSI C(我没用过,以下内容网上收集)
size_t strlcpy(char *dst, const char *src, size_t siz);
而使用 strlcpy,就不需要我们去手动负责 \0 了,仅需要把 sizeof(dst) 告之 strlcpy 即可:
strlcpy(path, src, sizeof(path));
len = strlen(path);
if ( len >= sizeof(path) )
printf("src is truncated.");