问题描述
我对缓冲区溢出感到困惑。我有一个代码,在其中声明了具有不同值数组的变量。 像
char name[20],address[30],account[15];
int id[10],dob[10],accountType[20];
但是后来我使用了 STRING_LEN 50 ,我将它赋予了每个 like
变量char name[STRING_LEN],address[STRING_LEN],account[STRING_LEN];
int id[STRING_LEN],dob[STRING_LEN],accountType[STRING_LEN];
因此,我使用了 fgets ,而不是使用 scanf 。我的问题是,即使我写了 STRING_LEN 或 sizeof 并由他们来管理,它也可以防止缓冲区溢出吗?还是我必须给每个变量赋予不同的值数组?
解决方法
使用类似char name[20];
的声明,您可以使用fgets函数,如下所示:
const char *p = fgets(name,sizeof name,stdin);
if (p != NULL) {
/*proceed*/
} else {
/*handle end of file*/
}
如果要从其他文件读取,请替换 stdin 。在这种情况下,fgets最多读取19个字符,并且(如果读取成功)以字符'\ 0'终止 name 。
另请参阅参考文档,网址为https://pubs.opengroup.org/onlinepubs/9699919799/