我们现在学的就是使用scanf()语句进行输入,但是vs2019中却报错显示不安全

首先我先来说一下scanf和scanf_s的区别
scanf()函数是标准C中提供的标准输入函数,用以用户输入数据
scanf_s()函数是Microsoft公司VS开发工具提供的一个功能相同的安全标准输入函数,从vc++2005开始,VS系统提供了scanf_s()。在调用该函数时,必须提供一个数字以表明最多读取多少位字符。
scanf()在读取数据时不检查边界,所以可能会造成内存访问越界

//例如:分配了5字节的空间但是

col1col2col3

用户输入了10字节,就会导致scanf()读到10个字节
char buf[5]={‘\0’};
scanf(“%s”, buf);
//如果输入1234567890,则5以后的部分会被写到别的变量所在的空间上去,从而可能会导致程序运行异常。

以上代码如果用scanf_s()则可避免此问题:

char buf[5]={‘\0′};
scanf_s(“%s”,buf,5); //最多读取4个字符,因为buf[4]要放’\0’
//如果输入1234567890,则buf只会接受前4个字符

对于解决这个报错问题有几个解决办法

1.最简单粗暴的

在使用vs2019时记住每次写scanf时全都写成scanf_s

2.在项目中进行属性的更改

第一步:创建空项目
选择创建新项目

选择空项目进行创建

2.创建源文件

右击

添加c++文件

3.更改属性

右击源.cpp

选择属性

此时常规中的SDL选项现实的是“是 (/sdl)”

将此处改为“否 (/sdl-)”并确认即可

此时虽然仍然会有警告出现,但是已经不影响程序的调试运行了,但是这个方法的缺点就是每一次创建新的c++文件的时候都要改一次属性,比较麻烦。

3.第三个办法:加宏

在最上面加上宏:

#define _CRT_SECURE_NO_WARNINGS 1

解除scanf的不安全问题

最后修改:2022 年 04 月 04 日
如果觉得我的文章对你有用,请随意赞赏