C标准库中不安全的函数

29 篇文章 2 订阅

C标准库中有一些函数存在副作用。虽然这些函数功能强大,但是如果忽略他们的副作用,会让整个应用不稳定。初期运行良好的代码,到了项目晚期,时不时崩溃。

一、字符串缓冲区溢出

函数严重性解决方案
strcpy很危险改为使用 strncpy。
strcat很危险改为使用 strncat。
sprintf很危险改为使用 snprintf,或者使用精度说明符。
scanf很危险使用精度说明符,或自己进行解析。
sscanf很危险使用精度说明符,或自己进行解析。
fscanf很危险使用精度说明符,或自己进行解析。
vfscanf很危险使用精度说明符,或自己进行解析。
vsprintf很危险改为使用 vsnprintf,或者使用精度说明符。
vscanf很危险使用精度说明符,或自己进行解析。
vsscanf很危险使用精度说明符,或自己进行解析。
streadd很危险确保分配的目的地参数大小是源参数大小的四倍。
strecpy很危险确保分配的目的地参数大小是源参数大小的四倍。
strtrns危险手工检查来查看目的地大小是否至少与源字符串相等。
realpath很危险(或稍小,取决于实现)分配缓冲区大小为 MAXPATHLEN。同样,手工检查参数以确保输入参数不超过 MAXPATHLEN。
syslog很危险(或稍小,取决于实现)在将字符串输入传递给该函数之前,将所有字符串输入截成合理的大小。
getopt很危险(或稍小,取决于实现)在将字符串输入传递给该函数之前,将所有字符串输入截成合理的大小。
getopt_long很危险(或稍小,取决于实现)在将字符串输入传递给该函数之前,将所有字符串输入截成合理的大小。
getpass很危险(或稍小,取决于实现)在将字符串输入传递给该函数之前,将所有字符串输入截成合理的大小。
getchar中等危险如果在循环中使用该函数,确保检查缓冲区边界。
fgetc中等危险如果在循环中使用该函数,确保检查缓冲区边界。
getc中等危险如果在循环中使用该函数,确保检查缓冲区边界。
read中等危险如果在循环中使用该函数,确保检查缓冲区边界。
bcopy低危险确保缓冲区大小与它所说的一样大。
fgets低危险确保缓冲区大小与它所说的一样大。
memcpy低危险确保缓冲区大小与它所说的一样大。
snprintf低危险确保缓冲区大小与它所说的一样大。
strccpy低危险确保缓冲区大小与它所说的一样大。
strcadd低危险确保缓冲区大小与它所说的一样大。
strncpy低危险确保缓冲区大小与它所说的一样大。
vsnprintf低危险确保缓冲区大小与它所说的一样大。

1、strcpy
原型声明:char *strcpy(char* dest, const char *src);
头文件:#include <string.h> 和 #include <stdio.h>
功能:把从src地址开始且含有NULL结束符的字符串复制到以dest开始的地址空间
说明:src和dest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串
返回:指向dest的指针。

在实际开发中,由于src大小会变化,往往不能时刻保证dest有足够空间,导致写入内容超过dest边界,侵入下一个变量。

 

 

 

二、输入缓冲区溢出

gets最危险使用 fgets(buf, size, stdin)。

三、内部使用全局变量导致线程不安全

rand产生随机整数1rand_r
strtok字符串split1strtok_r

四、函数返回静态变量的地址

asctimeasc时间2asctime_r
ctime时间戳2ctime_r
gethostbyaddr返回主机信息2gethostbyaddr_r
gethostbyname返回主机信息2gethostbyname_r
inet_ntoa转成IP2暂无
localtime返回本地时间2localtime_r

 

参考资料:
http://www.voidcn.com/article/p-whckshnh-uk.html    C语言中不安全的函数以及解决方案
https://vimsky.com/article/3185.html                            C语言线程安全:不可重入函数汇总
https://www.w3cschool.cn/cadvance/am9q1j5y.html    C语言 一些不安全的库函数
http://www.360doc.com/content/11/0610/16/6295074_126040631.shtml      C中不安全的函数
https://www.cnblogs.com/qintangtao/archive/2013/01/28/2879792.html       C语言中不安全的函数以及解决方案
https://blog.csdn.net/u014465639/article/details/71155515     C中不安全的函数以解决办法汇总
https://baike.baidu.com/item/strcpy/5494519?fr=aladdin        strcpy百度百科
 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值