-
Blocking I/O
一堆人去咖啡店买咖啡,第一个人点了咖啡后,就在柜台前等店员煮好咖啡;第一个人拿到咖啡后,才可以服务下一个人; -
Non-Blocking I/O
一堆人去咖啡店买咖啡,第一个人点了咖啡后,他一直会问店员,咖啡好了没?没好的话,等一会继续问;直到咖啡好了为止 -
I/O Multiplexing
店员回主动通知客人咖啡好了,但是客人还是需要站在柜台旁边等着select/poll/epoll
-
Signal-driven I/O
客人在柜台点餐后,客人就可以离开去干别的事情了;咖啡好了后店员主动通知客人;
和5的区别就是I/O分两部:1. 等网络上的数据到来; 2. 从内核态复制数据到用户态
4的话,是在1准备好后,就给客户通知了;
例如咖啡煮好了,也已经倒入杯子了,但是还没有从后厨运到前台的时候,就通知客户了,让客户自己去告诉前台,让前台去取咖啡给自己5的话,是在2准备好后,给客户通知;
例如咖啡煮好后,也已经搬运到前台了,通知客户咖啡好了,客户来了后就可以直接拿走咖啡了 -
Asynchronous I/O
客人在柜台点餐后,客人就可以离开去干别的事情了;咖啡好了后店员主动通知客人;
https://rickhw.github.io/2019/02/27/ComputerScience/IO-Models/
https://hechao.li/2022/01/04/select-vs-poll-vs-epoll/