作者godman362 (青)
看板NUU_CSIE
标题[心得] Asycn I/O
时间Mon Jul 27 18:00:26 2009
趁着有空闲,来写一下一般情况下如何写Async I/O的作法
在一般学习的时候,我们学得都是很直觉的写法
就是写完资料後开始读资料,或是读完资料後再写资料
而这样的作法,又称之为sync,中文称为同步作业
不过处理多人作业的话,或许就会死的很难看
假设写的是一个聊天软体,
不可能送完讯息後,还要等他回传才可以再送
我想这样的软体没人要用,而且程式要等到回传才会有反应
这样变成若是没有任何回传,程式就会挂在那边跟
当机一样
因此,我们需要的是Async作业方式
一般来说
Sync翻成同步作业,而
Async就会被翻译成非同步作业
不过这样的翻译方式并不是相当恰当,在LDD3(Linux Device Driver)书上有提到
因为Sync是因为作业方式一路走下来,所以翻译成同步没有问题
不过Async跟非同步一点关系也没有,所以是不恰当的翻法
因此书上提出一个「
不规律」的翻译方式,以下解释:
为何提出「
不规律」的翻法?
试着想想,在一般情况下,资料什麽时候会备妥?我们什麽时候可以写入/读取?
应该是完全不知道,或是说
无法预期
就是说我们对於外来的讯息,根本就不知道他什麽时候可以写入/读取
也因此,就变成了要
让资料自己告诉我们他已经备妥,而我们可以对他动作
这边就会衍生出
中断(Interrupt)的概念,不过在这边他被我要讲得东西包起来
所以先不用去管他
接着介绍在写Async I/O会用到的类型:
select、
poll
select就是一种利用中断概念所产生的API,也是
建议使用的API
poll的话,以中文的方式来说叫「
轮询」,是最
不建议使用的API
不过在介绍这两个API之前,必须先提一个东西:File Description(以下都称fd)
不用管他的中文,因为他一直没有很好的翻译
那fd是怎麽来的?
fd是藉由开启
某个档案,或是
某个装置所给予的编号
像是一般我们所谓的stdin、stdout、stderr也有编号,而且是固定:
stdin : 0
stdout : 1
stderr : 2
所以基本来说,开启之後的任何编号都是以3开始
像是以下,会就得到一个编号:
int Test_FD = open("test.txt", rb+);
这样以开启test.txt这个档案的编号,就是3
那我们要写入资料,或是读出资料,都是和fd做沟通
当然,不是只有开档案而已,前面也提到开启某装置一样会得到编号
不过在Windows底下只有开档案或是开Socket才会有
有了fd的概念,就可以继续来谈Async I/O的部份了
不过有点累,晚一点再打下一篇。
--
要
感谢的人太多了,那就
谢天吧
要
改得程式码太多了,那就
改天吧
--
※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 122.118.8.230
1F:推 osanaosana:很有用的文章... 07/27 18:03
2F:→ tuzr:请修周董的Unix程式设计就会学到fd了XD 07/28 02:07
3F:→ godman362:不想修周董的课啦....每次都修到睡着 07/28 08:37