BIO(Blocking IO,阻塞IO)、NIO(Non-blocking IO,非阻塞IO)和AIO(Asynchronous IO,异步IO)
假设你是一名快递员,要将包裹从仓库送到客户手中。以下是对BIO、NIO和AIO的形象解释:
BIO(Blocking IO,阻塞IO):这就像你是一名传统的快递员,当你要送货时,你进入仓库,并告诉工作人员要准备哪些包裹。然后你等待工作人员将包裹逐个交给你,你必须等待每个包裹都准备好后才能离开仓库。在这个过程中,你不能去派送其他包裹,只能一直等待。这就是BIO的工作方式,当一个IO操作被调用时,程序将被阻塞,直到操作完成才能继续执行。
NIO(Non-blocking IO,非阻塞IO):现在,你成为了一位更高效的快递员。不再等待工作人员将包裹逐个交给你,而是主动询问他们是否已经准备好了所有包裹。如果包裹准备好了,你可以立即拿起它们并开始派送。如果还有包裹未准备好,你可以继续询问其他工作人员或者去派送已准备好的包裹。这就是NIO的工作方式,当一个IO操作被调用时,程序将立即返回,不会被阻塞,可以继续执行其他任务。通过使用选择器(Selector)和事件通知机制,NIO可以实现非阻塞的IO操作。
AIO(Asynchronous IO,异步IO):现在,你变成了一名更高级的快递员,你不仅可以主动询问工作人员包裹是否准备好,还可以异步地等待他们通知你包裹已经准备好了。这样,你可以同时处理多个包裹的派送,无需等待每个操作完成。你告诉工作人员可以稍等片刻,然后去派送已准备好的包裹。当工作人员通知你包裹准备好了,你再回来继续派送。这就是AIO的工作方式,当一个IO操作被调用时,程序会立即返回,它会在后台进行处理,并通过回调机制通知操作的完成。
其中NIO基于select模型实现,AIO基于epoll模型实现(windows下是基于iocp)