IO(Input/Output,输入输出)
在计算机中,输入/输出(即IO)是指信息处理系统(比如计算机)和外部世界(可以是人或其他信息处理系统)的通信。输入是指系统接收的信号或数据,输出是指从系统发出的数据或信号。由于程序和运行时数据是在内存中驻留,由CPU这个超快的计算核心来执行,涉及到数据交换的地方,通常是磁盘、网络等,就会有IO产生。
同步-异步
同步和异步是一种消息通信机制 (synchronous communication/ asynchronous communication),关注点在于 被调用者返回
和 结果返回
之间的关系, 描述对象是被调用对象的行为。
1 | # 同步(Synchronous):在发出一个同步调用时,在没有得到结果之前,该调用就不返回,等待返回结果才继续执行后续的操作。 |
阻塞-非阻塞
阻塞和非阻塞是一种业务流程处理方式。关注点在于调用发生时 调用者状态
和 被调用者返回结果
之间的关系。 描述的是等待结果时候调用者的状态。 此时结果可能是同步返回的,也能是异步返回。
1 | # 阻塞( Blocking ):在结果返回之前,当前线程被挂起,后续代码只有在结果返回后才能执行。 |
同步阻塞-同步非阻塞
实际编程中,通过线程实现进程的同步非阻塞,通过协程实现线程的同步非阻塞。
1 | # 同步阻塞:打电话问老板有没有某书(调用),老板说查一下,让你别挂电话(同步),你一直等待老板给你结果,什么事也不做(阻塞)。 |
异步阻塞-异步非阻塞
1 | # 异步阻塞:打电话问老板有没有某书(调用),老板说你先挂电话,有了结果通知你(异步),你挂了电话后(结束调用), 除了等老板电话通知结果,什么事情也不做(阻塞)。 |
IO模型
5种 I/O 模型:
- 阻塞式I/O
- 非阻塞式I/O
- I/O复用(select,poll,epoll…)
- 信号驱动式I/O(SIGIO)
- 异步I/O(POSIX的aio_系列函数)
IO模型的具体解释可以参考 linux五种IO模型
参考资源
- 链接:https://juejin.im/post/5c725dbe51882575e37ef9ed
- 链接:https://phenix3443.github.io/notebook/software-engineering/synchronous-asynchronous-blocking-nonblocking.html
- 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。