关于c标准库函数gets的危害
来源:互联网 发布:淘宝露肩lolita衬衫 编辑:程序博客网 时间:2024/04/29 08:56
gets从标准输入设备读字符串函数。
原 型 char * gets ( char * str );
gets可以无限读取,不会判断上限,所以程序员应该确保buffer的空间足够大,以便在执行读操作时不发生溢出。如果溢出,多出来的字符将被写入到堆栈中,这就覆盖了堆栈原先的内容,破坏一个或多个不相关变量的值。这个事实导致gets函数只适用于玩具程序,为了避免这种情况,我们可以用fgets(stdin) (fgets实际上可以读取标准输入(即大多数情况下的键盘输入),具体参阅fgets词条)来替换gets()。在V7的手册(1979年)中说明:为了向后兼容,gets删除换行符,gets并不将换行符存入缓冲区。
由于可以无限读取,所以在2011年12月,ANSI 采纳了 ISO/IEC 9899:2011 标准,标准中删除了 gets()函数,使用一个新的更安全的函数gets_s()替代。
#include <stdio.h>#include <string.h>int main(int argc, char const *argv[]){char c0;char c1;char c2;char c3;gets(&c0);printf("%c%c%c%c\n", c0,c1,c2,c3);return 0;}/**测试下
$./a.out abcabc
*/
0 0
- 关于c标准库函数gets的危害
- 关于标准库函数qsort()的使用
- C标准库函数abs的一个错误
- C 标准库函数getchar的陷阱
- C标准库函数abs的一个错误
- 操纵 C 风格字符串的标准库函数
- C语言中常用的标准库函数
- C 中标准库函数 qsort 的用法
- ISO的C语言标准库函数分类
- C语言标准库函数getenv的实现
- C标准库函数浅析
- C标准库函数(a)
- .调用标准C库函数
- c标准库函数
- C标准库函数浅析
- c标准库函数列表
- C标准库函数
- C: 标准库函数 floor
- iptables
- 笔记(8)
- 【深入分析Java多线程】(7)Lock
- 网站优化
- 1.jQuery选择器和事件
- 关于c标准库函数gets的危害
- 【USACO2008NOV】采购干草——会做的题目做错才可惜_耀晨SYW
- 利用yarn多队列实现hadoop资源隔离
- All O`one Data Structure
- Java 事件监听原理及Demo实现
- 纯JS实现排列整齐的数据表格
- 使用别人demo需要复制的东西
- gulp+webpack+angular1的一点小经验(第三部分使用一些angular1的插件ui-bootstrap与highcharts)
- ID