?
? 按照《Unix网络编程》的划分,IO模型可以分为:阻塞IO、非阻塞IO、IO复用(select/poll/epoll)、信号驱动IO和异步IO,按照POSIX标准来划分只分为两类:同步IO和异步IO
?
? 如何理解这几个概念,我个人来言,可以从java线程的角度去分析。现在有件事情,我要去图书馆借书,那我本人就是一个线程,借书是个事件,假如借书这个事件要花好长时间,比如管理员找书拿书,那线程就只能等到拿到书,才能做别的事情,这个就是同步但是线程一直在运算不能说是阻塞。假如恰好这个时候图书馆有其他人再借书,然后图书管理员给我说你等会,那对于线程来说,就好比调用了wait一直在等待,这个就是阻塞,线程阻塞在借书这个事情上。我去,借个书你还让我在这里等一天,这不是浪费我的青春年华嘛,于是乎给管理员留个电话号码,找到叫我,而我这个线程可以去做别的事情,这个时候好比管理员是一个线程,我是一个线程,我在管理员上面注册了一个事件,这个就是一种设计模式,现在借书这个事情就分两步了,一个是注册借书事件,一个是处理事件,所以是异步完成的,同时我这个线程可以不用在挂起,也就是非阻塞的。
?
??? 同步与异步? 简单的理解分几个线程,一个线程肯定是同步的
??? 阻塞与非阻塞? 简单理解线程调用是否被挂起或等待