这是一个非常基本的C问题,来自Kernighan和Ritchie的第18页.
我编译了这个非常简单的代码来计算从键盘输入的字符:
#include <stdio.h>
/* count characters in input; 1st version */
main()
{
long nc;
nc = 0;
while (getchar() != EOF)
++nc;
printf("%1d\n", nc);
}
Run Code Online (Sandbox Code Playgroud)
这个编译很好,运行正常,并且表现得非常符合预期,即如果我输入"Hello World",当我按下CTRLD以给出EOF字符时,它返回值11 .
令我困惑的是,如果我犯了错误,我可以使用退格键删除字符并重新输入它们,它只返回终端在调用EOF时显示的字符数.
如果代码计算每个字符,包括特殊字符,如果我输入四个字符,删除两个,再输入另外两个,那么输出不应该是8个字符(4个字符+2个del + 2个字符),而不是4个字符?
我显然误解了C如何处理退格,以及代码如何/何时递增变量nc?
通常,您的终端会话以"行模式"运行,也就是说,它只在行完成时将数据传递给您的程序(例如,您按下Return等).因此,您只能在完成后看到该行(在您的程序看到任何内容之前已完成任何编辑).通常这是一件好事,因此每个程序都不需要处理delete/etc.
在大多数系统(例如基于Unix的系统等)上,可以将终端置于"原始"模式 - 也就是说,每个字符都按接收方式传递给程序.例如,面向屏幕的文本编辑器通常会这样做.
这不是getchar()不计算"删除",但它甚至没有看到输入,直到它被终端驱动程序传递给您的程序.
当您输入内容时,在您按下\n或发送EOF(或EOL)之前,它不会到达您的C程序.这就是POSIX定义为Canonical Mode Input Processing - 通常是默认模式.
| 归档时间: |
|
| 查看次数: |
1064 次 |
| 最近记录: |