聊聊 IO

聊聊IO

1、I/O:Input/Output

磁盘 IO:读写磁盘文件

网络 IO:读写 socket 文件

标准输入输出:读写控制台

2、阻塞 IO

应用进程发起 read() 请求之后,调用recvfrom()阻塞,直到数据进入数据接收队列。

数据准备好之后,从内核拷贝到应用进程,应用进程进行数据解析,整个过程应用进程是阻塞的

2次阻塞 一次是TCP连接,一次是读数据的时候

3、非阻塞 IO

应用进程发起 read() 请求,如果数据没有准备好,则立即返回一个返回值,应用进程收到之后,会不断发起 read() 请求,直到内核准备好数据,这个时候应用进程阻塞着,直到数据由内核拷贝到应用进程,应用进程进行数据解析。

可以调用 fcntl 将客户端连接套接字设置为非阻塞

fcntl(client_fd,F_SETFL,0_NONBLOCK);

总结:

BIO:去书店买书,没有我想要的书,我一直在书店等。

NIO:去书店买书,如果没有我想要的书,我走,隔一天再来买,直到有书了。轮询有一点就是浪费 CPU

第二种 NIO:买书的时候,提前给老板打电话,有这本书了,我再来买。多路复用

4、多路复用

IO 多路复用模型中,线程首先发起 select 请求,询问内核数据是否就绪了,等内核把数据准备好了,应用进程再发起 read 请求

Java 中的 NIO ,有一个选择器,也可以被称为多路复用器。通过它,只需要一个线程便可以管理多个客户端连接。

5、select、poll、epoll

select

poll

epoll

相关推荐
纪元A梦2 分钟前
分布式锁算法——基于ZooKeeper的分布式锁全面解析
java·分布式·算法·zookeeper
翻滚吧键盘9 分钟前
spring打包,打包错误
java·后端·spring
_Djhhh13 分钟前
基于SpringAOP面向切面编程的一些实践(日志记录、权限控制、统一异常处理)
java·spring boot·spring·maven·sprint
张张张31224 分钟前
4.1学习总结 拼图小游戏+集合进阶
java·学习
拾荒的小海螺26 分钟前
JAVA:使用 Curator 进行 ZooKeeper 操作的技术指南
java·zookeeper·java-zookeeper
SoFlu软件机器人1 小时前
Go/Rust 疯狂蚕食 Java 市场?老牌语言的 AI 化自救之路
java·golang·rust
半盏茶香1 小时前
启幕数据结构算法雅航新章,穿梭C++梦幻领域的探索之旅——堆的应用之堆排、Top-K问题
java·开发语言·数据结构·c++·python·算法·链表
hweiyu001 小时前
idea如何让打开的文件名tab多行显示
java·ide·intellij-idea·idea·intellij idea
小吴先生6661 小时前
Groovy 规则执行器,加载到缓存
java·开发语言·缓存·groovy
星星不打輰2 小时前
Spring基于注解进行开发
java·spring