我们学c语言的时候一定对于scanf函数很不陌生(如果陌生就完蛋了),我们写的代码其实就是一行行的字符串,是由编译器来吧字符串给编译成为cpu可以执行的代码,而scanf在从标准输入得到数据的时候也是一样的,他默认为读取的就是字符串,只不过按照你的%d之类的制表符来读取后又转换罢了。
其实是由一个输入字符的缓冲区在的,他们可以看作一个输入的队列,在输入的时候把每队列的头部取出检验,假设是%d的说明符,比如第一个取出的是数字,那么就把这个字符串转换成为数字放在对应的地址上,如果是字符的话,就认为不能读取,就返回0,就代表读取失败,给大家看一段代码:
int main()
{
int n;
int res1,res2;
res1 = scanf("%d",&n);
res2 = scanf("%c",&n);
printf("%d %d %c",res1,res2,n);
return 0;
}
输出结果是:
q
0 1 q
由于第一个输入的是字符,所以scanf函数跳了过去,直接向后读取了。
如果是%c的说明符,那么就直接读取任何一个字符即可。
如果是%s的说明符那么就读取字符串知道遇见了一个tab或者换行,空格。
其实是由一个输入字符的缓冲区在的,他们可以看作一个输入的队列,在输入的时候把每队列的头部取出检验,假设是%d的说明符,比如第一个取出的是数字,那么就把这个字符串转换成为数字放在对应的地址上,如果是字符的话,就认为不能读取,就返回0,就代表读取失败,给大家看一段代码:
int main()
{
int n;
int res1,res2;
res1 = scanf("%d",&n);
res2 = scanf("%c",&n);
printf("%d %d %c",res1,res2,n);
return 0;
}
输出结果是:
q
0 1 q
由于第一个输入的是字符,所以scanf函数跳了过去,直接向后读取了。
如果是%c的说明符,那么就直接读取任何一个字符即可。
如果是%s的说明符那么就读取字符串知道遇见了一个tab或者换行,空格。