gets, gets_s
来自cppreference.com
| 定义于头文件 <stdio.h>
|
||
| char *gets( char *str ); |
(1) | (C11 中移除) |
| char *gets_s( char *str, rsize_t n ); |
(2) | (C11 起) |
2) 从 stdin 读取字符直到发现换行符或出现文件尾。至多写入 n-1 个字符到
str 所指向的数组,并始终写入空终止字符(除非 str 是空指针)。若发现换行符,则忽略它并且不将它计入写入缓冲区的字符数。
目录 |
[编辑] 参数
| str | - | 要被写入的字符串 |
| n | - | char数组的最大长度 |
[编辑] 返回值
成功时为 str ,失败时为空指针。
若文件尾条件导致了失败,则附加设置 stdin 的文件尾指示器(见 feof() )。若其他某些原因导致了失败,则设置 stdin 的错误指示器(见 ferror() )。
[编辑] 注解
gets() 函数不进行边界检查,从而此函数对缓冲区溢出攻击极度脆弱。无法安全使用它(除非程序运行的环境限定能出现在 stdin 上的内容)。因此,此函数在 C99 的第三次勘误中被弃用,而在 C11 标准发布时被移除。推荐的替代品是 fgets() 和 gets_s() 。
绝对不要用 gets() 。
[编辑] 引用
- C11 标准(ISO/IEC 9899:2011):
- K.3.5.4.1 The gets_s function (p: 602-603)