strcpy注意点

原型声明: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开始推出的安全版本,并不是标准库,所以,不推荐使用.


  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值