scanf函数不安全: C4996 ‘scanf‘: This function or variable may be unsafe. Consider using scanf_s instead

解决 scanf 函数不安全

  • 1. 为什么说 scanf 函数不安全
  • 2. 为什么不直接用 scanf_s
  • 3. 解决方法一:
  • 4. 解决方法二: 一劳永逸的方法
      • 步骤一: 找到 newc++file.cpp 文件
      • 步骤二: 更改文件
  • 5. 解决方法三:

代码报错:
scanf函数不安全: C4996 ‘scanf‘: This function or variable may be unsafe. Consider using scanf_s instead_第1张图片

1. 为什么说 scanf 函数不安全

scanf函数易受缓冲区溢出攻击的影响,可能导致安全问题。
scanf_s函数是一种更安全的选择,它将缓冲区的大小作为参数并避免了缓冲区溢出攻击

举个栗子:
字符数组的大小为 5 , 若输入的字符串字符数目不超过 5 ,那么没问题,
(注意字符串后面默认会多出来一个 ‘\0’ )

scanf函数不安全: C4996 ‘scanf‘: This function or variable may be unsafe. Consider using scanf_s instead_第2张图片

如果超过 5 了, 就出现问题了, 程序崩了, 但是字符串能正常打印出来, 说明字符串放进去了,
由此可见, scanf 不管能不能放得下, 都会往内存里面放,这样就会导致数组越界, 非法访问其他的内存

scanf函数不安全: C4996 ‘scanf‘: This function or variable may be unsafe. Consider using scanf_s instead_第3张图片

2. 为什么不直接用 scanf_s

scanf_s 是 VS 编译器提供的函数, 并不是 C 语言提供的库函数
如果用 scanf_s , 那么写的代码在 非 VS 编译器上编译不能通过, 降低了代码的可移植性

3. 解决方法一:

代码的首行加上:

#define _CRT_SECURE_NO_WARNINGS 1

告诉编译器忽略相关的警告信息。消除编译时使用标准 C/C++ 函数(如 scanf、gets 等)时产生的安全警告

scanf函数不安全: C4996 ‘scanf‘: This function or variable may be unsafe. Consider using scanf_s instead_第4张图片

4. 解决方法二: 一劳永逸的方法

为了不每次创建文件时都要添加这一行代码, 我们可以设置每次创建文件时自动加上这行代码

步骤一: 找到 newc++file.cpp 文件

D: VS 的安装路径\Common7\IDE\VC\VCProjectItems

scanf函数不安全: C4996 ‘scanf‘: This function or variable may be unsafe. Consider using scanf_s instead_第5张图片

如果不容易找到的话, 这里推荐一款非常得力的 文件查找工具: Everything

Everything下载链接

步骤二: 更改文件

文件中添加:

#define _CRT_SECURE_NO_WARNINGS 1

注意: 直接更改并保存是没有权限的,
可以先将文件复制一份到其他位置, 更改后, 再拷贝过来将之前的文件替换掉即可

用记事本打开并添加:

scanf函数不安全: C4996 ‘scanf‘: This function or variable may be unsafe. Consider using scanf_s instead_第6张图片

这样以后每次新建文件都会自动出现这个东西啦

5. 解决方法三:

代码首部加上:

#pragma warning(disable:4996)

与方法一类似, 都是为了消除编译器产生的警告信息
只不过 4996 这个编译器警告编码是针对scanf的警告
scanf函数不安全: C4996 ‘scanf‘: This function or variable may be unsafe. Consider using scanf_s instead_第7张图片

好了,以上就是我为大家分享的三种方法, 推荐第二种, 希望能帮到你!
评论区欢迎指正!

你可能感兴趣的:(C语言,c语言)