JAVA IO模型

JAVA IO模型

常见的IO模型有:阻塞IO模型、非阻塞IO模型、多路复用IO模型、信号驱动IO模型、异步IO模型。

一、阻塞IO模型

阻塞IO模型是最传统的一种IO模型,就是在读写数据过程中会发生阻塞现象。当用户线程发出IO请求后,内核就会去查看数据是否准备就绪,如果没有就绪,就会等待数据就绪,此时的用户线程就处于阻塞状态。当数据就绪之后,内核就会将数据拷贝到用户线程,并返回结果给用户线程,用户线程解除block状态。

二、非阻塞IO模型

当用户线程发起一个IO请求后(如read操作),并不需要等待,而是马上得到一个结果,如果结果是error,此时用户线程就知道数据还没有准备好,接着用户线程会继续发送read操作,直到内核中的数据准备好,用户线程又发送了read操作之后,那么内核就会马上把数据拷贝到用户线程,并返回结果。非阻塞IO模型并不会阻塞线程,但是会不断地询问内核数据是否就绪,持续占用CPU,导致CPU占用率非常高,一般情况下很少使用。

// 典型的非阻塞IO模型
while(true){
    data = socket.read();
    if(data!= error){
        // 处理数据
        break;
    }
}

三、多路复用IO模型

java中的NIO实际上就是多路复用IO。多路复用IO模型中,会有一个线程不断地去轮询多个socket的状态,只有socket发出读写请求时,才会有真正的IO读写操作。

java NIO的三大核心部分:

  1. Buffer(缓冲区):每个客户端连接都会对应一个Buffer,读写数据通过缓冲区读写。

  2. Channel(通道):每个Channel用于连接Buffer和Selector,通道可以及逆行双向读写。

  3. Selector(选择器):一个选择器可以对应多个通道,用于监听多个通道的事件。Selector可以监听所有Channel是否有数据需要读取,当某个Channel有

评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值