zoukankan      html  css  js  c++  java
  • c输入函数细节

    1,输入函数被调用后,它首先检查输入缓冲区内的字符数量是否已满足输入要求,若满足,则直接从缓冲区读入;若缓冲区内的字符数量不满足输入要求,则等待用户输入。通常输入完成的标志是用户输入回车\n,这时输入函数会重复之前的步骤——检查输入缓冲区的字符数量是否满足输入要求,若满足...若不满足... 

    看例子:

    1 #include<stdio.h>
    2 void main(void){
    3     int v1,v2;
    4     scanf("%d%d",&v1,&v2);
    5         printf("scanf end\n");
    6         return;
    7 }
    View Code


    gcc -o  t  test.c

    ./t

    1  //程序进入等待输入状态,我们输入1,回车
        //程序仍处于等待输入状态,因为检测到缓冲区里只有一个”1“,而scanf需求两个整数。这里再输入回车
    1//程序仍处于等待输入状态,我们输入一个整数1并回车
    scanf end//scanf函数完成读取工作并返回
    shell returned 2

    但,getc()函数是不以\n作为输入完成标志的,只要用户输入,它立即开始处理并返回。


    2,所有输入函数共用一个输入缓冲区。

    看例子:

    #include<stdio.h>
    void main(void){
    	int v1,v2;
    	scanf("%d%d",&v1,&v2);
    	printf("%d",getchar());
    	return;
    }
    


    gcc -o  t  test.c

    ./t

    1 2
    10//输出回车键的ascii码,10

    ./t

    1 2 3

    32//这里并未输出“3”的ascii码,因为“2”后面有空格,而getchar()是不跳过空格的。

    shell returned 2

      由此也看出回车是比较特殊的输入,它向输入函数发出“用户输入完毕”的通知,也在输入缓冲区留下一个"\n"字符。

  • 相关阅读:
    hdu 4308(bfs)
    数位dp
    hdu 4548(素数打表)
    不要把时间浪费在QQ上
    用插值方法构造多项式证明中值问题
    《摩诃般若波罗蜜多心经》 玄奘 译
    证明高斯引理
    《摩诃般若波罗蜜多心经》 玄奘 译
    若一整系数$n$次多项式在有理数域可约,则总可以分解成次数小于$n$的两整系数多项式之积.
    用teamviewer控制内网计算机
  • 原文地址:https://www.cnblogs.com/weiweishuo/p/3082605.html
Copyright © 2011-2022 走看看