Loading... <div class="tip share">请注意,本文编写于 1363 天前,最后修改于 746 天前,其中某些信息可能已经过时。</div> 我们现在学的就是使用scanf()语句进行输入,但是vs2019中却报错显示不安全 ![](/usr/uploads/2021/08/2398371035.png) > 首先我先来说一下scanf和scanf_s的区别 > scanf()函数是标准C中提供的标准输入函数,用以用户输入数据 > scanf_s()函数是Microsoft公司VS开发工具提供的一个功能相同的安全标准输入函数,从vc++2005开始,VS系统提供了scanf_s()。在调用该函数时,必须提供一个数字以表明最多读取多少位字符。 > scanf()在读取数据时不检查边界,所以可能会造成内存访问越界 > > //例如:分配了5字节的空间但是 > > > | col1 | col2 | col3 | > | ------ | ------ | ------ | > | | | | > | | | | > > 用户输入了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.在项目中进行属性的更改 第一步:创建空项目 选择创建新项目 ![](/usr/uploads/2021/08/2734515467.png) 选择空项目进行创建 ![](/usr/uploads/2021/08/3129973901.png) 2.创建源文件 ![](/usr/uploads/2021/08/3845883405.png) 右击 ![](/usr/uploads/2021/08/126368681.png) ![](/usr/uploads/2021/08/2980834506.png) 添加c++文件 3.更改属性 ![](/usr/uploads/2021/08/4151288088.png) 右击**源.cpp** ![](/usr/uploads/2021/08/1266131361.png) 选择属性 ![](/usr/uploads/2021/08/3392022094.png) 此时常规中的SDL选项现实的是“是 (/sdl)” ![](/usr/uploads/2021/08/1249476741.png) 将此处改为“否 (/sdl-)”并确认即可 ![](/usr/uploads/2021/08/2872033986.png) 此时虽然仍然会有警告出现,但是已经不影响程序的调试运行了,但是这个方法的缺点就是每一次创建新的c++文件的时候都要改一次属性,比较麻烦。 ### 3.第三个办法:加宏 在最上面加上宏: ``` #define _CRT_SECURE_NO_WARNINGS 1 ``` 解除scanf的不安全问题 最后修改:2022 年 04 月 04 日 © 允许规范转载 打赏 赞赏作者 支付宝微信 赞 1 如果觉得我的文章对你有用,请随意赞赏