首页 > 文档
优化设计,在 IO 方面应该注意哪些要点
- 2024-05-30
- 1067 ℃
I/O 基础介绍
I/O(Input/Output)意思是输入输出,其实就是数据传递的一个过程,作为后台服务需要更多地与外部进行数据交互,那么就免不了 I/O 操作。I/O 的类型也是非常多的,我们应该掌握常用的一些 I/O 模型分类。
I/O 分为以下 5 种模型,在介绍分类之前,我们先了解 I/O 在系统层面会有 2 个阶段(以读为例子):
第一个阶段是读取文件,将文件放入操作系统内核缓冲区;
第二阶段是将内核缓冲区拷贝到应用程序地址空间。
1.阻塞 I/O
例如读取一个文件,我们必须要等待文件读取完成后,也就是完成上面所说的两个阶段,才能执行其他逻辑,而当前是无法释放 CPU 的,因此无法去处理其他逻辑。
2.非阻塞 I/O
非阻塞的意思是,我们发起了一个读取文件的指令,系统会返回正在处理中,然后这时候如果要释放进程中的 CPU 去处理其他逻辑,你就必须间隔一段时间,然后不停地去询问操作系统,使用轮询的判断方法看是否读取完成了。
3.多路复用 I/O
这一模型主要是为了解决轮询调度的问题,我们可以将这些 I/O Socket 处理的结果统一交给一个独立线程来处理,当 I/O Socket 处理完成后,就主动告诉业务,处理完成了,这样不需要每个业务都来进行轮询查询了。
相关内容
25年政治考研徐涛全程辅...
C语言进阶
专升本重要知识点资料
初高中教师资格证面试通...
办公物品管理表格 - 企...
初中古诗文考点特训
企业公文\新闻信息范例
不一样的六级 大学英语...
-
中医综合历年真题
2024-08-20 2033
-
JavaScript核心参考手册
2024-05-24 1331
-
大规模分布式存储系统 ——原理解析与架构实战
2024-05-24 1048
-
算法技术手册
2024-05-24 1148
-
产品技术研发 - 企业管理表格
2024-07-31 1170
-
办公室工作日程通用表格 - 企业管理表格
2024-07-31 1357
-
新东方在线【晨读】超能听口训练营
2024-08-20 964
-
程序员修炼之道 专业程序员必知的33个技巧
2024-05-28 1248
-
工具应用:使用 clinicj 工具实现通用性安全检查
2024-05-24 1385
-
采购管理单据 - 企业管理表格
2024-07-31 1246
文章评论 (0)
- 这篇文章还没有收到评论,赶紧来抢沙发吧~


下载完整资料
点击分享文章