简单来讲,scanf会强行输入内容,所以是不安全的。
我们来看这样的例子:
#include <iostream>
using namespace std;
int main()
{
char demo[3];
scanf("%s", demo);
return 0;
}
对于以上代码,当我们输入字符不超过3时,程序可以正常运行,但当我们输入字符大于3,scanf仍将所有输入字符存入数组,这显然会导致数组的错误访问,因此VS认为scanf是不安全的。
解决办法
第一,我们可以使用scanf_s,它是VS提供的,但若使用它将意味着程序只能在VS编译器运行,显然是不合理的。
第二种方法是在程序开头加上”#define _CRT_SECURE_NO_WARNINGS 1“
但是如果我们每次打开都需要输入的话是比较麻烦的。因此,我们可以搜索new++file.cpp文件将该句子加到文件当中,以后在创建新的程序时VS就会自动在开头加上。
路径参考:D:\Program Files\Microsoft Visual Studio\2022\Community\Common7\IDE\VC\VCProjectItems
找到文件后使用记事本打开并输入”#define _CRT_SECURE_NO_WARNINGS 1“即可,如图。