Linux安全网 - Linux操作系统_Linux 命令_Linux教程_Linux黑客

会员投稿 投稿指南 本期推荐:
搜索:
您的位置: Linux安全网 > Linux编程 > » 正文

常忘了的字符串处理函数的细节问题

来源: kangquan2008 分享至:

1.strncat 避免缓冲区溢出

 strncat(dest, src, sizeof(dest)-strlen(dest)-1); // 会加'\0',留一个位置
2.strncat是不会自己添加'\0'的,要自己添加 

      strcpy(dest, src, sizeof(dest) - 1); // 不会加'\0',留一个位置给下语句加
      dest[sizeof(dest)-1] = '\0';

或则使用strncat来保证(前一种好,避免了初始化的遍历)        

memset(dest,0,sizeof(dest));
strncat(dest, src, sizeof(dest)-1); // 会加'\0',留一个位置

3.fgets\fgetc\gets\getc

会接受回车,在fgets、gets会接受n-1个,然后在n-1添加'\0',然后剩下的下一次接收,需要对'\n'进行特殊处理,判断是不是'\n',将其去掉,

scanf();不用处理'\n',但不安全

4.snprintf()也会接受n-1个,然后在n-1添加'\0',所以一般声明变量时用 char str[LEN + 1],然后 snprintf(dest, LEN , "%s%s",...)

5.不安全的函数别用,避免缓冲区溢出。


Tags:
分享至:
最新图文资讯
1 2 3 4 5 6
验证码:点击我更换图片 理智评论文明上网,拒绝恶意谩骂 用户名:
关于我们 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 发展历史