0x7B3D8F41 (ucrtbased.dll)处(位于 Project2.exe 中)引发的异常: 0xC0000005: 写入位置 0x006A1357 时发生访问冲突。

 初学c语言,在学习 用scanf函数输入数据时写了点代码(上图所示),调试过程中未报错,but运行后却出现如上问题,原因如下在于未能正确理解scanf于scanf_s的区别。

scanf_s()用于读取字XIU符串时,必须提供一个数字以表明最多读取多少位字符,以防止溢出。

 在scanf_s中指定最多读取多少位字符后运行成功!

当时用scanf_s输入数组、字符、字符串时必须添加第三个参数,用来表示缓冲区的大小,表示最多读取n-1个字符(整数、浮点数等不需要最后一位)。

scanf于scanf_s的区别:

scanf() 函数 :

scanf() 函数是格式化输入函数,它从标准输入设备(键盘) 读取输入的信息。
其调用格式为:scanf("<格式化字符串>",<地址表>)。





scanf_s()函数:

scanf_s() 的功能虽然与scanf() 相同,但却比 scanf() 安全,因为 scanf_s() 是针对“ scanf()在读取字符串时不检查边界,可能会造成内存泄露”这个问题设计的。

scanf_s()用于读取字符串时,必须提供一个数字以表明最多读取多少位字符,以防止溢出。

  • 10
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值