如何通过给变量提供相同的值数组来防止缓冲区溢出?

问题描述

我对缓冲区溢出感到困惑。我有一个代码,在其中声明了具有不同值数组的变量。

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/