从缓冲输流到Linux控制台的历史.pdf

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
从⾮缓冲输⼊流到 Linux控制台的历史 ⽬录 可以设置不带缓冲的标准输⼊流吗 这和缓存⽆关,是控制台的实现⽅式的问 题。 strace查看了下 如果想感受⼀下rawmode 终端上的字符编程 Linux控制台的历史 这篇也是源⾃于⽔源C板上板友的⼀个问题,涉及 Linux上的控制台的实现⽅式和历史原因。因为内容⽐较 ⻓,所以在这⾥再排版⼀下发出来。原帖在这⾥。 可以设置不带缓冲的标准 输⼊流吗 WaterElement(UnChanged)于2014年12⽉09⽇ 23:29:51星期⼆问到 : 请问对于标准输⼊流可以设置不 带缓冲吗 ⽐如以下程序 1 #include stdio.h 2 #include unistd.h 3 4 int main(int argc, char *argv[ ]) 5 FILE *fp = fdopen(STDIN_FI LENO, r); 6 setvbuf(fp, NULL, _IONBF, 0 ); 7 char buffer[20]; 8 buffer[0] = 0; 9 fgets(buffer, 20, fp); 10 printf(buffer is:%s, buf fer); 11 return 0; 12 } 似乎还是需要在命令⾏输⼊后按 回⻋才会让fgets返回,不带缓冲究 竟体现在哪⾥ 这和缓存⽆关,是控制台的实现 ⽅式的问题。 再讲细节⼀点,这⾥有很多个程序和设备。以下按 linux的情况讲 : 1. 终端模拟器窗⼝ (⽐如xterm)收到键盘事件 2. 终端模拟器(xterm)把键盘事件发给虚拟终端pty1 3. pty1检查⽬前的输⼊状态,把键盘事件转换成 stdin的输⼊,发给你的程序 4. 你的程序的c库从stdin读⼊⼀个输⼊,处理 标准库说的输⼊缓存是在4的这⼀步进⾏的。⽽⾏ 输⼊是在3的这⼀步被缓存起来的。 终端pty有多种状态,⼀般控制台程序所在的状态叫 「回显⾏缓存」状态,这个状态的意思是: 1. 所有普通字符的按键,会回显到屏幕上,同时记录 在⾏缓存区⾥。 2. 处理退格( BackSpace ),删除( Delete )按键为 删掉字符,左右按键移动光标。 3. 收到回⻋的时候把整个⼀⾏的内容发给stdin。 参考 : /wiki/Cooked_mode 同时在Linux/Unix下可以发特殊控制符号给pty让它 进⼊ 「raw」状态,这种状态下按键不会被回显,显⽰ 什么内容都靠你程序⾃⼰控制。如果你想得到每⼀个按 键事件需要⽤raw状态,这需要⾃⼰控制回显⾃⼰处理缓 冲,简单点的⽅法是⽤readline这样的库 (基本就是 「回显⾏缓存」的⾼级扩展,⽀持了Home/End,⽀持 历史)或者ncurses这样的库 (在raw状态下实现了⼀个 简单的窗⼝/事件处理框架)。 参考 : /wiki/POSIX_terminal_interfa ce#History 除此之外, Ctrl-C 转换到SIGINT, Ctrl-D 转 换到EOF这种也是在3这⼀步做的。 以及,有些终端模拟器提供的 Ctrl-Shift-C 表⽰ 复制这种是在2这⼀步做的。 以上是Linux/unix的⽅式。Windows的情况⼤体类 似,只是细节上有很多地⽅不⼀样 : 1. 窗⼝事件的接收者是创建cmd窗⼝的Win32⼦系 统。 2. Win32⼦系统接

文档评论(0)

youbika + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档