黑马程序员技术交流社区

标题: 为什么gets函数是不安全的? [打印本页]

作者: liulinjie    时间: 2014-6-22 17:40
标题: 为什么gets函数是不安全的?
在Xcode中使用gets会提示是不安全的。为什么?
是因为会覆盖外面的内存空间,所以提示不安全吗? 比如
char a[5] = "abcd";
char b[5];
gets(b);     // 输入
printf("b = %s, a = %s", b , a);
如果输入的内容多于4个字节,就会覆盖数组a存储的内容。
但是我试了一下,使用scanf函数如果输入的字符多于4个,也会覆盖a的数据。
那为什么使用gets会提示是不安全的?


作者: 骑着飞机去看海    时间: 2014-6-22 23:19
因为gets函数有一定的缺陷性,列如,gets函数是不检查边界的,有人可以利用gets()不检查边界,用输入进行攻击,所以不安全,还有就是使用gets()函数容易内存溢出,如,输入的字符串大于数组的容量时字符串就溢出了,另外.gets()函数接收的输入字符大小不受限制。
作者: ios风痕    时间: 2014-6-24 00:48
用scanf函数就行写为 scanf(“%c”,a);亲测可用





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2