C语言中 scanf_s和 scanf 区别
来源:互联网 发布:上海有mac专柜吗 编辑:程序博客网 时间:2024/04/28 17:23
转自 https://zhidao.baidu.com/question/123882045.html
scanf()函数是标准C中提供的标准输入函数,用以用户输入数据
scanf_s()函数是Microsoft公司VS开发工具提供的一个功能相同的安全标准输入函数,从vc++2005开始,VS系统提供了scanf_s()。在调用该函数时,必须提供一个数字以表明最多读取多少位字符。
原因和区别:
scanf()在读取数据时不检查边界,所以可能会造成内存访问越界:
//例如:分配了5字节的空间但是用户输入了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个字符
注: scanf_s最后一个参数n是接收缓冲区的大小(即buf的容量),表示最多读取n-1个字符.
PS: 很多带“_s”后缀的函数是为了让原版函数更安全,传入一个和参数有关的大小值,避免引用到不存在的元素,防止hacker利用原版的不安全性(漏洞)黑掉系统。
0 0
- C语言中 scanf_s和 scanf 区别
- scanf_s和scanf区别
- C语言中,保证输入输出的正确:scanf(),scanf_s(), gets(), getchar()
- scanf和scanf_s
- vs编译器中scanf_s与scanf的区别。
- scanf() 与 scanf_s() 的区别
- scanf与scanf_s的区别
- scanf() 与 scanf_s() 的区别
- C语言中scanf和gets的区别
- C语言中scanf(),sscanf(),fscanf()的用法和区别
- C语言中gets()和scanf()的区别
- C语言scanf()和gets()的区别
- C语言中Scanf和Printf
- C语言中scanf()和缓冲区
- scanf()函数与scanf_s()函数的区别
- c语言中 scanf
- C语言中scanf
- C语言常见错误杂谈(一)scanf()、scanf_s()与错误 C4996与解决方法
- 安装pyv8
- Saruman's Army 【辐射区间贪心】
- 算法训练 整数平均值
- 循环的优化
- 异常:org.springframework.beans.factory.BeanNotOfRequiredTypeException
- C语言中 scanf_s和 scanf 区别
- 动态规划C语言初学
- nginx编译安装与配置-配置篇
- 访问WEB-INF下的JSP
- 飞龙的安卓逆向系列教程
- 排序算法
- 【SQL】trucate、drop、delete 的区别
- 华为5c手机刷机
- 异常:java.lang.ClassNotFoundException: org.hibernate.engine.FilterDefinition