getchar()函数是从缓冲区读入数据。
在程序中使用getchar()函数时应当使用回车符结束数据的输入,但是当用户输入的数据都保存在缓冲区内,包括回车符,于是在运行下一个getchar()函数时仍然从缓冲区读入数据就读到了输入第一个变量时(为结束输入而)留下的回车符,导致这个getchar无法接收到第二个变量的值,从而造成各种问题。
这时只有在两个负责接收变量的值的getchar函数中间加入一个getchar()(不用赋值)或者scanf(“%c”);就可以啦。
以此类推,在使用输入形如scanf("%d%c%d",&a,&b,&c)时也可能遇到类似的问题,在使用方才的两种解决方法的同时,在%d和%c的中间加一个空格同样可以防止空格、回车、制表符的错误读入,例如scanf("%d %c%d",&a,&b,&c);
行缓冲(Line-buffer)输入方式:
*将输入字符放入缓冲队列中,再从缓冲队列中读取字符。
*直到键入回车符或者文件结束符EOF时,程序才认为输入结束。
*一行输入结束时,getchar()才开始从缓冲队列中读入字符,前面函数队列中没读走的字符依然留在缓冲队列中,等待下一个函数来进行读入(包括用于结束输入的空格、回车等)。(‘、n’的ASCII值是10)
这种输入方式相当于键盘输入的一行字符都放入缓冲区,再从缓冲区逐个读入字符。
为什么getchar()要读到一个回车符或文件结束符EOF才进行一次处理操作呢?
为什么getchar()以行(而非字符)为单位读取字符呢?
*实际上是按文件的方式读取字符
*文件一般都是以行为单位的。
在Windows下遇到Ctrl+Z返回负值(EOF,一般定义为-1)