scanf的两个参数

2022-12-05 投稿:张伟杰 分享

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_s("%d%c", &i );

这句后面加个

getchar();

而且你这明明是两个说明符,怎么赋给一个变量,用%*c接收一个字符(但不赋值)

最后scanf_s和scanf的用法不同,需要三个参数,最后一个是要读入的字节数(用sizeof确定)

建议将程序中的所有scanf_s替换为scanf

然后在代码第一行前面加

#define _CRT_SECURE_NO_WARNINGS

屏蔽警告

scanf_s("%s",names[count],20);

您好,不一样的哦,请看下面的明细:

================================

格式控制符:

%---格式说明引导符。

----指定左对齐输出。

0---指定空位填零。

m.n --- 指定输出域宽度及精度。

l.h---输出长度的修正。

格式字符:

%i---输出一个整型数;

%d---输出一个整型数;

%f---输出一个浮点数;

%e---输出一个浮点数,科学计数法;

%g---输出一个浮点数,当指数小于-4或者大于5,则运用科学计数法,否则正常显示浮点数;

%c---输出一个字符;

%o---输出一个八进制的整型数,前面不带0;

%#o---输出一个八进制的整型数,前面带0;

%x---输出一个十六进制的整型数,前面不带0x;

%#x---输出一个十六进制的整型数,前面带0x, 如果x大写,则显示的时候也是大写。

%u---不带符号的十进制整数。

%%---输出一个%.

转义字符:

\a:蜂鸣,响铃

\b:回退:向后退一格

\f:换页

:换行,光标到下行行首

:回车,光标到本行行首

\t:水平制表

\v:垂直制表

\\:反斜杠

\':单引号

\":双引号

\?:问号

\ddd:三位八进制

\xhh:二位十六进制

\0:空字符(NULL),什么都不做

printf的格式控制的完整格式:

% - 0 m.n l或h 格式字符

下面对组成格式说明的各项加以说明:

①%:表示格式说明的起始符号,不可缺少。

②-:有-表示左对齐输出,如省略表示右对齐输出。

③0:有0表示指定空位填0,如省略表示指定空位不填。

④m.n:m指域宽,即对应的输出项在输出设备上所占的字符数。N指精度。用于说明输出的实型数的小数位数。为指定n时,隐含的精度为n=6位。

⑤l或h:l对整型指long型,对实型指double型。h用于将整型的格式字符修正为short型。

#scanf的两个参数#相关文章

scanf函数的用法及注意事项

scanf 的意思是把输入的值给送到地址,因此,如果参数已经是地址了,那么不需要 &,否则 需要用&取一下地址scanf 格式输入函数函数作用:按照变量在内存的地址将变量值存进去。一般

0.2万人浏览 scanfscanf函数Scanf的用法

scanf函数的功能是按什么规定的格式

C语言中scanf 用于输入,与printf函数一样,都被定义在头文件stdio.h里,因此在使用scanf函数时要加上#include <stdio.h>。它是格式输入函数,即按用户指定

0.2万人浏览 scanfscanf函数scanf是