C语言关于在vs中使用scanf不安全的问题

关于在vs中使用scanf不安全的问题

首先是scanf为什么不安全

首先是关于内存溢出的问题,scanf在使用的时候不会检测你输入的字符串长度所以这时就有内存溢出的风险。

#include<stdio.h>
int main()
{
    char arr[6]={0};
    scanf("%s",&arr);
    //假设输入helloworld就会出现越界访问的问题,所以scanf在这种情况下会不安全。
}

其次是如何解决scanf不安全的问题

解决这个问题有两个方法
1.一个是打开vs 项目选项看到最后一个选项属性
在这里插入图片描述

将SDL检查禁用
2.在文件.c中第一行插入下面这段代码;
#define _CRT_SECURE_NO_WARNINGS

在每个文件的开头都插入显然略显麻烦,所以还有一个一劳永逸的方法,下面我来介绍一下。首先找到你的vs安装路径找到这个文件newc++file.c将他复制到桌面上然后在将上面一段代码复制进去,再将这个文件复制回原来的路径底下。替换原来的文件即可。*那么这里为什么要这莫做呢,因为当你在原来路径直接更改newc++file.c会提示你没有权限更改。

最后是为什么scanf_s安全

vs中提供的scanf_s 函数需要规定输入字符的个数,所以需要额外输入一个限定数字。这样就可以保证函数不会越界访问。

#include<stdio.h>
int main()
{
    char arr[6];
    scanf_s("%s",&arr,5);//那么这个时候就不会造成意外的越界访问
    return 0;
}

只会有人为的越界访问比如你要输入hello五个字符却只定义了arr[5]那么字符串结尾的\0;会因为无处安放而造成越界。
当然我还是建议在日常编程中使用scanf因为scanf_s是vs自己写出来的在其他的编译器上会报错,可复用性太差。

以上文件我都上传在了我的码云,需要的可以看看
链接

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

KissKernel

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值