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

代码报错:
在这里插入图片描述

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

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

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

在这里插入图片描述

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

在这里插入图片描述

2. 为什么不直接用 scanf_s

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

3. 解决方法一:

代码的首行加上:

#define _CRT_SECURE_NO_WARNINGS 1

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

在这里插入图片描述

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

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

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

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

在这里插入图片描述

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

Everything下载链接

步骤二: 更改文件

文件中添加:

#define _CRT_SECURE_NO_WARNINGS 1

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

用记事本打开并添加:

在这里插入图片描述

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

5. 解决方法三:

代码首部加上:

#pragma warning(disable:4996)

与方法一类似, 都是为了消除编译器产生的警告信息
只不过 4996 这个编译器警告编码是针对scanf的警告
在这里插入图片描述

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

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值