c语言scanf和scanf_s的区别,详解

Python029

c语言scanf和scanf_s的区别,详解,第1张

1、使用区别

scanf()不会检查输入边界,可能造成数据溢出。

scanf_s()会进行边界检查。

2、意思

scanf表示从键盘输入指定格式的数据。如:scanf("%d",x)指从键盘给x输入一个int型(整型)数据;scanf("%f",x)指从键盘给x输入一个float型(实型)数据;

对应的输出为:printf 按照指定的格式输出数据;如printf("%d",x) 指按整型数据输出X中的值。

因为带“_s”后缀的函数是为了让原版函数更安全,传入一个和参数有关的大小值,避免引用到不存在的元素,防止hacker利用原版的不安全性(漏洞)黑掉系统。

3、scanf_s()参数与scanf()不同

例如scanf(“%s”,&name,n),整形n为name类型的大小,如果name是数组,那n就是该数组的大小。

scanf 的意思是把输入的值给送到地址,因此,如果参数已经是地址了,那么不需要 &,否则 需要用&取一下地址

scanf 格式输入函数

函数作用:按照变量在内存的地址将变量值存进去。

一般格式:scanf(格式控制,地址表列)

其中,格式控制:

%d:以带符号的十进制形式输出整数

%o:以八进制无符号形式输出整数

%x:以十六进制无符号形式输出整数

%u:以无符号十进制形式输出整数

%c:以字符形式输出,只输出一个字符

%s:输出字符串

%f:以小数形式输出单,双精度数,隐含输出六位小数

%e:以指数形式输出实数

%g:选用%f或%e格式中输出宽度较短的一种格式,不输

出无意义的0

在格式控制的字母前面可以用几种常见的格式符的修饰符,作用如下:

L:用于长整型整数,可加在格式符d,o,x,u前面

M(代表一个正整数):数据最小宽度

N(代表一个正整数):对实数,表示输出n位小数;

对字符串,表示截取的字符个数

地址列表:是由若干个地址组成的表列,可以是变量的地址,或字符串的首地址

举例:

用scanf函数输入数据。

#include

void main()

{

int a,b,c

scanf(“%d%d%d”,&a,&b,&c)

printf(“%d,%d,%d\n”,a,b,c)

}

运行情况:3 4 5 (回车) (输入a,b,c的值)3,4,5 (输出a,b,c的值)

使用scanf函数时应注意的问题 :

(1)scanf函数中的“格式控制”后面应当是变量地址,而不应

是变量名。

(2) 如果在“格式控制”字符串中除了格式说明以外还有其他字符,

则在输入数据时在对应位置应输入与这些字符相同的字符。

(3) 在用“%c”格式输入字符时,空格字符和“转义字符”都作为

有效字符输入

(4) 在输入数据时,遇以下情况时认为该数据结束。

① 遇空格,或按“回车”或“跳格”(Tab)键;

② 按指定的宽度结束,如“%3d”,只取3列;

③ 遇非法输入。