行缓冲——getchar()的内在原理

本文探讨了C语言中getchar函数在处理行缓冲输入时可能出现的问题,即因回车符留在缓冲区导致的输入混乱。解决方案包括在getchar之间插入额外的读取函数或在格式字符串中添加空格。理解缓冲区的工作原理对于避免这类问题至关重要。
摘要由CSDN通过智能技术生成

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)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值