scanf()函数是c语言中的标准输入,与printf()函数天生一对。当我们有变量之后,想要往变量里添加数值,这时候就要用到scanf()函数了。
scanf()函数是用来读取用户在键盘上的输入,程序运行到这一步时,会停下来等待用户的输入,用户输入数据并摁下回车键,scanf()函数就会处理输入值,存入变量。
scanf()函数的语法跟printf()函数相似。都需要占位符,占位符跟printf()基本一致。
#include<stdio.h>
int main()
{
int score = 0;
printf("请输入成绩:");
scanf("%d", &score);//& - 取地址符
printf("成绩是:%d", score);
return 0;
}
运行代码:
scanf()函数是用来读取用户在键盘上的输入,程序运行到这一步时,会停下来等待用户的输入。
在屏幕上输入数字:
然后按下回车:
用户输入数据并摁下回车键,scanf()函数就会处理输入值,存入变量。
输入同样的内容,不同的占位符会有不一样的解释。
#include<stdio.h>
int main()
{
int a;
scanf("%d", &a);
printf("a = %d", a);
return 0;
}
输入123,输出:
#include<stdio.h>
int main()
{
int a, b, c;
scanf("%c%c%c", &a, &b, &c);
printf("a = %c\nb = %c\nc = %c\n", a, b, c);
return 0;
}
输入123,输出:
上面两个代码输出均为“123”,但含义却不同,第一个是整数123,第二个是三个字符分别为1,2,3。
这是因为c语言分有很多数据类型,scanf()需要提前知道用户输入的类型才能处理数据。
一次性读入多个变量:
#include<stdio.h>
int main()
{
int a, b;
float c, d;
scanf("%d%d%f%f", &a, &b, &c, &d);
printf("a = %d\n", a);
printf("b = %d\n", b);
printf("c = %f\n", c);
printf("d = %f\n", d);
return 0;
}
运行上述代码:
(-4.0e3:-4.0*10*10*10 -4.0×十的三次方 科学计数法)
连续输入时,不同输入值要用空白字符隔开。
scanf()处理数值占位符时,会自动过滤空白字符,包括空格、制表符、换行符等。所以,用户输入的数据之间有一个或多个空格不影响scanf()解读数据。回车键将输入分成几行也不影响。
scanf()处理用户输入的原理是,用户的输入先放入缓存,等到按下回车键后,按照占位符对缓存进行解读。解读用户输入时,会从上一次解读遗留的第一个字符开始,直到完成缓存,或者遇到第一个不符合条件的字符为止。
#include<stdio.h>
int main()
{
int x;
float y;
scanf("%d", &x);
scanf("%f", &y);
printf("x = %d\n", x);
printf("y = %f\n", y);
return 0;
}
运行上述代码,
上面输入:-12.34e123 3
输入的内容先放在缓存区,按下回车键后对缓存进行解读,第一个占位符为%d,代表输入一个整数,从‘-’开始直到小数点停下(即遇到第一个不符合条件的字符)(整数中不可能出现小数点)
然后第二个占位符为%f,代表输入一个小数,从上一次解读遗留的第一个字符开始,y输出0.34e12.(这里0.34计算机可能无法精确保存 但是是十分接近的 四舍五入是一样的)
scanf()函数的返回值是一个整数,表示成功读取的变量个数。
如果没有读取任何项,或者匹配失败,则返回0。
如果在成功读取任何数据之前,发生了读取错误或者遇到读取到文件结尾,则返回常量EOF(EOF - end of file 文件结束标志 EOF的值为-1)。
#include<stdio.h>
int main()
{
int a = 0;
int b = 0;
float f = 0.0f;//0.0 默认为double类型,在后面加f,表示float类型
int ret = scanf("%d %d %f", &a, &b, &f);
printf("a = %d\n", a);
printf("b = %d\n", b);
printf("f = %f\n", f);
printf("ret = %d\n", ret);
return 0;
}
运行上述代码,并输入:10 20 3.4
输入:10 20 e
这里ret的值就变成 2 了,因为小数中没有e,所以没有读取成功。
这里若想要强行结束输入,输入三个Ctrl+z。这里是成功读取两个数后强行结束。
这里一个数据都没有成功读取,则ret为-1;
scanf()常用的占位符如下,跟printf()的占位符基本一致。
%c:字符
%d:整数
%f:float类型浮点数
%lf:double类型浮点数
%Lf:long double类型浮点数
%s:字符串
%[ ] : 在方括号中指定一组匹配的字符(比如%[ 1 - 9 ] ),遇到不在集合之中的字符,匹配停止
上面所有占位符之中,除了%c以外,都会自动忽略起手的空白字符。%c不忽略空白字符,总是返回当前第一个字符,无论该字符是否为空格。
若想要跳过字符前的空白字符,可以写成 scanf(“ %c”,a);在%c前加一个空格,这样就可以跳过一个或多个空白字符。
%s的读取是从第一个非空白字符开始读取,到空白字符停止。
%s不会包含空白字符,所以无法用来读取多个单词,除非多个%s一起使用。这也意味着,scanf()不适合读取可能包含空格的字符串。
scanf()将字符串读入字符数组时,不会检测字符串是否超过了数组长度,所以,使用%s占位符时,应该指定读入字符串的最长长度,即写成%[m]s,其中的[m]是一个整数,表示读取字符串的最大长度,后面的字符将被丢弃。
有时用户输入可能不符合预定格式:
#include<stdio.h>
int main()
{
int year = 0;
int month = 0;
int day = 0;
scanf("%d-%d-%d", &year, &month, &day);
printf("%d-%d-%d", year, month, day);
return 0;
}
运行上述代码,
若用户没有规范输入:
scanf()会指定输入格式,为了避免这种情况,scanf()提供了一个赋值忽略符*,只要把*加在任意占位符的百分号后面,该占位符就不会返回值,解析后将被丢弃。
#include<stdio.h>
int main()
{
int year = 0;
int month = 0;
int day = 0;
scanf("%d%*c%d%*c%d", &year, &month, &day);
printf("%d-%d-%d", year, month, day);
return 0;
}
运行上述代码,
对于想了解更多信息的,可以在网站查资料,网站:https://legacy.cplusplus.com