在C语言里,什么时候用scanf函数呢?

如题所述

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<stdio.h>
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列;
③ 遇非法输入。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2018-03-09
scanf 用于输入
与printf函数一样,都被定义在头文件stdio.h里,因此在使用scanf函数时要加上#include <stdio.h>。它是格式输入函数,即按用户指定的格式从键盘上把数据输入到指定的变量之中。

函数 scanf() 是从标准输入流stdio (标准输入设备,一般是键盘)中读内容的通用子程序,可以说明的格式读入多个字符,并保存在对应地址的变量中。

返回值
scanf()函数返回成功赋值的数据项数,读到文件末尾出错时则返回EOF。
如:
scanf("%d %d",&a,&b);

如果a和b都被成功读入,那么scanf的返回值就是2
如果只有a被成功读入,返回值为1
如果a和b都未被成功读入,返回值为0
如果遇到错误或遇到end of file,返回值为EOF。
且返回值为int型.
例:使用scanf函数输入数据。

#include<stdio.h>
int main(void)
{
int a,b,c;
printf("输入a,b,c\n");
scanf("%d%d%d",&a,&b,&c);
printf("a=%d,b=%d,c=%d\n",a,b,c);
fflush(stdin);
return 0;
}
第2个回答  2018-03-09
scanf函数是C语言标准中的格式化输入函数,他的最简单作用是从标准输入设备(键盘)获取一个值到一个存储空间中

ex:
scanf("%d",&a);
上例中语句的意思是,从键盘缓冲区读入一个值,放入a变量的存储空间,也就是a的值为你用键盘输入的值

故可得出结论,scanf用于从键盘输入数据时使用,可以理解为被用作人机交互的一个接口设备的控制函数

ps:标准输入设备不只有键盘一个,如果需要更换,还可以重定向至其他设备

满意请采纳,不满意请追问
第3个回答  2018-03-09
要存储输入的值的时候用scanf。比如要把3存到变量a中
scanf("%d",&a);
对应的是要输出的时候用printf.
printf("%d",a);
http://wenku.baidu.com/link?url=j6h1IlZBX_OHL2QAq81f8ynY7f5fXgUnwrggyb64KCOQ7ZF7LM9sssk-UqeuP_lIOAjPHpx8txx-CgXP1av-4HlHo5b6UKCNAmzlrZQN-O3
你可以看一下,希望对你有帮助
第4个回答  2018-03-09
需要从标准输入流中读取字符串时就可以使用。