strcpy注意点

来源:互联网 发布:网络盒子怎样双清 编辑:程序博客网 时间:2024/06/05 18:50

原型声明: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.");


strncpy_s版本则是从VS2005开始推出的安全版本,并不是标准库,所以,不推荐使用.