今天,在电脑上安装了VS2017,因为以前一直使用的是VC6.0和Dev_cpp,所以第一次使用VS有些笨拙。
今天建立的第一个C程序“hello world!”便于到的很大的难题
运行无误之后,在原先的代码上添加了一些内容如下:
本来一个简单的程序,却出现了异常:

于是将这段代码放在Dev_cpp上运行,结果运行无误,百思不得其解。
1、根据提示,在文件顶部加入一行:#define _CRT_SECURE_NO_WARNINGS
运行成功!
2、在文件顶部添加代码:#pragma warning(disable:4996)
运行成功!
3、真正原因在与vs中的SDL检查。于是可以:右键单击工程文件-->属性--------> c/c++ ------>SDL checks ------------> no
按照错误提示,可以将 scanf 替换为 scanf_s
运行成功
但是将这段代码放进Dev_cpp,却出错了:

于是引发了一些关于scanf_s 的一些思考:
找了一些资料
ANSI C中没有scanf_s(),只有scanf(),scanf()在读取时不检查边界,所以可能会造成内存泄露。所以VS中提供了scanf_s()
在最新的VS2017中也提供了scanf_s()在调用时,必须提供一个数字以表明最多读取多少位字符。
如果想继续使用scanf这个不安全的函数可以使用宏命令来阻止错误的产生
#define _CRT_SECURE_NO_DEPRECATE
请把宏命令放在最前面
或者编译选项中加/D_CRT_SECURE_NO_DEPRECATE
或者在所有.c/.cpp文件前面添加#pragma warning(disable:4996)
- 函数是标准C中提供的标准输入函数,用以用户输入数据
- 函数是Microsoft公司VS开发工具提供的一个功能相同的安全标准输入函数,VS系统提供了scanf_s()。在调用该函数时,必须提供一个数字以表明最多读取多少位字符。
scanf()在读取数据时不检查边界,所以可能会造成内存访问越界:
PS: 很多带“_s”后缀的函数是为了让原版函数更安全,传入一个和参数有关的大小值,避免引用到不存在的元素,防止hacker利用原版的不安全性(漏洞)黑掉系统。
在我们刚使用vs时,在使用scanf函数时会遇到下面的这种情况,会出现这种情况的,发生这种情况的原因是VS认为scanf这个函数不安全产生的,那么怎么解决呢,下面我简单说几种解决方法。

首先找到你安装VS的路径然后按下面路径找到E:VS2019Common7IDEVCVCProjectItems 文件夹

在里面找到newc++file.cpp这个文件 ,然后将这个文件复制到桌面上用vs打开,然后将#define _CRT_SECURE_NO_WARNINGS 1 复制到里面,保存退出,最后将桌面上的文件转移到原路径下,并替换掉源文件,这样就好了,并且在以后创建.c文件时,系统都会默认添加这行代码在你的.c文件里,以后就不会出现问题了


找到你创建的项目,右击找到属性,找到c/c±---->常规---->SDL检查,将 是改为否 最后点击确定就行了。
不够这种方法在每次创建新项目是都要设置一下,比较麻烦,所以还是推荐使用方法一,设置一次后以后创建新文件都不用设置了。




以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
到此这篇vs怎么用scanf输入(vs使用scanf)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!版权声明:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权、违法违规、事实不符,请将相关资料发送至xkadmin@xkablog.com进行投诉反馈,一经查实,立即处理!
转载请注明出处,原文链接:https://www.xkablog.com/cjjbc/37268.html