VS使用scanf函数报错解决方法

VS使用scanf函数报错解决方法VS 使用 scanf 函数报错解决方法

VS使用scanf函数报错解决方法

首先来看一段很简单的C语言代码

#include 
  
    int main(void) { char s[10];    scanf("%s",s);    printf("%s",s); return 0; } 
  

这段代码的作用就是输入一个字符串,再把这个字符串输出。在其他IDE(集成开发环境)上,是完全可以运行的,但是在Microsoft Visual Studio(美国微软公司开发的可视化编程开发软件)的系列软件上(从Microsoft Visual C++ 2005开始),Microsoft Visual Studio系列软件直接使用scanf函数会报错,但是也提供了一个叫scanf_s新格式化输入函数。


scanf_s函数

在调用scanf_s函数时,必须在可变参数表中提供一个数字来表明最多读取多少个字节的字符,另外很多额外带_s后缀的函数是为了让原版函数更安全,传入一个和参数有关的大小值,避免访问到不存在的元素。

所以上面那段代码在VS2019里要这样写:

#include 
   
     int main() {    char s[10];    scanf_s("%s",s,10);    printf("%s",s);    return 0; } 
   

scanf_s(“%s”, a,10);表示用户最多可以最多输入9个字符,这种情况程序可以正常编译运行,如果用户输入字符超过9个,程序运行结果就会出错。scanf_s函数的可变参数表里的10表示可以输入9个字符,因为s[9]里要存放’\0’字符。


scanf_s函数和scanf函数的区别

scanf函数 :是标准格式化输入函数,它从标准输入设备(键盘)读取输入的信息。其调用格式为:scanf(“

scanf_s函数:是针对scanf函数在读取字符串时不检查边界,可能会造成内存泄露这个问题设计的。scanf_s函数用于读取字符串时,必须提供一个数字以表明最多读取多少位字符,以防止溢出。

scanf函数和scanf_s函数在整数、浮点数、单个字符等输入情况下基本功能相同。 两者的主要区别在于字符串的输入。


VS使用scanf函数报错解决方法

如果我们在VS2019环境下直接使用scanf函数,程序会产生以下报错:

解决方法一

使用scanf_s函数来代替scanf函数。


解决方法二

点VS2019软件上方的工具→打开项目→打开属性页→打开配置属性→打开C/C++→在预处理器中添加_CRT_SECURE_NO_WARNINGS,点击确定

%K%4P4CO3_6B(4Z$LOFQ55R.png

JCXLH7]A9J81XDMUG8RI5VV.png


解决方法三

在代码最最上面加入一句宏定义:#define _CRT_SECURE_NO_WARNINGS

#define _CRT_SECURE_NO_WARNINGS #include 
       
         int main() {    char s[10];    scanf("%s",s);    printf("%s",s);    return 0; } 
       

解决方法四

在代码最最上面加入一句代码:#pragma warning(disable:4996),作用是忽略此警告

#pragma warning(disable:4996) #include 
        
          int main() { char s[10]; scanf("%s", s); printf("%s",s); return 0; } 
        

欢迎大家来加我自己的编程语言交流群号:

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/214314.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月18日 下午4:33
下一篇 2026年3月18日 下午4:33


相关推荐

  • FFmpeg H264编码

    FFmpeg H264编码FFmpeg 进行 h264 的编码流程 1 通过编码器名 查找编码器 h264 编码器名字是 libx264 2 设置编码器的参数 比如码率 分辨率 帧率 时间基等 3 打开编码器 avcodec open2 4 对帧数据进行编码 avcodec send frame 将帧送到编码器 avcodec receive packet 从编码器获取编码后的数据包 编码完后写入文件 在实际使用中帧数据来源于解码后的元数据或来源于摄像头 本文示例的帧数据时人工添加了模拟数据 相关 AP

    2026年3月18日
    2
  • GPT-5免费指南,手把手教你使用OpenAI最强模型

    GPT-5免费指南,手把手教你使用OpenAI最强模型

    2026年3月15日
    2
  • 关于@(posedge clk)和@(itf.cb)的区别

    关于@(posedge clk)和@(itf.cb)的区别一 采样 region 区别 posedgeclk 采样是在 activeregion 相当于 observeregio 这里会采样最新的值 itf cb 采样会在 preponeregio 二 具体示例代码在这里插入代码片

    2026年3月16日
    1
  • 数据格式汇总及type, astype, dtype区别「建议收藏」

    数据格式汇总及type, astype, dtype区别「建议收藏」标签(空格分隔):pythonuint8在此输入正文8位的无符号整形数据取值范围从0到255一singed与unsigned的区别二float改变类型643264to32shape翻倍改变类型321632to16shape翻倍改变类型32float32tofloatshape还原float默认是float64改变类型float64intfloat64

    2022年6月11日
    43
  • 起步上路「建议收藏」

    起步上路「建议收藏」始于2016-09-11开篇,中间基于工作的内容,记录了几篇相关内容的博客,离上一次发博客(2017-07-24),也过了1年多的时间。这个期间,开始转战人工智能方向,深度学习算法的内容。几经磨难,算是踏入门槛,期间也记录了些许内容。期间也看了各路朋友相关的博客内容,其中不乏精彩之作,为初学者提供了很好的帮助。目前接触和比较熟悉的是目标检测相关的内容,大多基于caffe深度学习框架,博客内容不…

    2022年6月9日
    53
  • 数据库建表规则_SQL创建数据表

    数据库建表规则_SQL创建数据表–数据库建表语句的规范小结建表语句的规范:1.字段的设计   A.数据类型尽量用数字类型,数字类型的比字符类型的要快很多。  B.数据类型尽量小,这里的尽量小是指在满足可以预见的未来需求的前提下的,但是有不能太小,  上次监控系统里面的表mon_tair_stat_detail_2012_1的data_size和use_size定义的是int(15)实际上

    2025年8月26日
    8

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号