JAVA的NIO模型

什么是NIO

java的NIO全称为non-blocking IO,使用它可以提供非阻塞式的高伸缩性网络

NIO的基本组成

NIO主要有三部分:Channel、Buffer和Selector
Channel是一个对象,可以用过它进行数据的读取和写入,它是面向缓冲区的,所有的数据都通过Buffer来处理,永远不会直接将字节写入通道中,而是将数据写入包含一个字节或者多个字节的缓冲区

早多线程模式下,阻塞IO时,一个线程只能处理一个请求,比如Http请求,当请求响应式关闭连接,释放线程资源。Selector选择器的作用就是配合一个线程来管理多个Channel,获取这些Channel上发生的事件,这些Channel工作在非阻塞模式下,不会让线程一直在一个Channel上,适合连接数特别多,但流量低的场景

调用Selector的select()方法会阻塞直到Channel发送了读写就绪事件,这些事件发生,select()方法就会返回这些事件交给thread来处理。

在这里插入图片描述

NIO的epoll BUG

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值