IO 作为操作系统的核心知识之一, 无论是在本机、传统的单体应用、还是分布式系统中,都有非常重要的地位.
今天就和大家系统地聊一聊 IO 相关的东西.
IO
IO,Input/Output 简写,是指内存和外设之间的数据复制的过程. 输入是指数据从外设复制到内存中, 输出则是指数据从内存复制到外设.
根据外设种类可以分为磁盘IO和网络IO, 因为外设的数据读写速率较低以及 IO 会涉及到系统调用以及中断,所以通常都会比较耗时。在程序优化时思路之一就是减少 IO 。
软件开发中的 IO
软件开发中各开发语言都提供了 IO 操作的方法或函数, 但应用程序在执行 IO 方法时, 实际上由两步完成,第一步:执行程序,发起系统调用,第二步系统执行 IO 。返回时则首先将数据读入到内核空间,然后内核空间再将数据复制给应用程序。
Unix IO 模型
Unix 根据应用程序 IO 的两个阶段特征将 IO 分为 5 种类型.
1. BIO
阻塞 IO, 服务器在 accept(),read(),write(), 数据没有 ready 前会一直阻塞线程.
2. NIO
非阻塞 IO, 服务器在 accept(),read(),write(