<C语言学习>scanf和scanf_s的区别

本文探讨了C语言中scanf()函数的安全隐患,指出它不会检查输入边界可能导致数据溢出。相比之下,scanf_s()函数提供了一种更安全的解决方案,因为它会检查输入边界。使用scanf_s()时,可以通过指定缓冲区大小防止溢出,例如在输入字符串时推荐使用带三个参数的scanf_s()。在VS2017中,scanf()已被舍弃,转而强制使用scanf_s()进行输入操作。
摘要由CSDN通过智能技术生成
  • scanf()不会检查输入的边界,因此输入的数据可能会溢出,导致程序出错
  • scanf_s()更安全,其会检查输入的边界

如:

char ch[6];
scanf("%s",ch);

若此时输入数据为abcdefghijk,则f以后的内容将溢出到别的空间,可能会导致程序运行错误


若使用
scanf_s("%s",ch);

则输入数据abcdefghijk,只会接受abcdef六个输入,其余的不接受


若是
scanf_s("%s",ch,6);
则输入数据abcdefghijk,只会接受abcde五个输入,因为ch[6]要放置"\0".

PS:输入字符串时建议使用这个


PS:

  • scanf_s()最后一个参数n是接收缓冲区的大小(即ch的容量),表示最多读取n-1个字符.

  • 输入 字符串 时建议使用接受3个参数的scanf_s(),并且注意输入时长度不要超过n(容量)-1;
    输入数字可使用接受2个参数的scanf_s()

  • vs2017已经不再使用scanf()输入数据,只能用scanf_s(),否则会报错

  • 本人仍处于摸索阶段,以上仅为个人阅读文章及实践后的一些理解

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值