java面试-0136-BIO、NIO、AIO区别?

BIO:同步阻塞模型。线程处理I/O请求时会阻塞(accept、read、write阻塞)。实现模式为一个线程处理一个连接,可用线程池优化。适合连接数少,并发量低的场景。如简单的文件传输。基于Socket和ServerSocket

NIO:同步非阻塞模型。通过Selector轮询通道Channel,非阻塞读写数据(select阻塞,accept、read、write非阻塞)。实现模式为一个线程通过seletor管理多个连接,适合高并发I/O 密集型的场景。如Web 服务器、实时通信系统。基于SocketChannel和ServerSocketChannel

AIO:异步非阻塞模型。基于事件驱动,I/O 操作由操作系统完成,通过回调(如 CompletionHandler)或Future返回结果。适合连接数较多且连接时间长的场景,如大型分布式系统

import java.net.;import java.nio. ;import java.nio.channels.;import java.util. ;

public class NIOServer{

public static void main(String[]a)throws Exception{

Selector s=Selector.open();

ServerSocketChannel ss=ServerSocketChannel.open();

ss.bind(new InetSocketAddress(9999));ss.configureBlocking(false);

ss.register(s,SelectionKey.OP_ACCEPT);

while(true){

s.select();

for(Iteratorit=s.selectedKeys().iterator();it.hasNext()😉{

SelectionKey k=it.next();it.remove();

if(k.isAcceptable()){

SocketChannel c=ss.accept();c.configureBlocking(false);

c.register(s,SelectionKey.OP_READ);

}else if(k.isReadable()){

SocketChannel c=(SocketChannel)k.channel();

ByteBuffer b=ByteBuffer.allocate(1024);

if(c.read(b)==-1){c.close();continue;}

b.flip();c.write(b);

}

}

}

}

}

相关推荐
辞砚技术录23 分钟前
MySQL面试题——联合索引
数据库·面试
nbsaas-boot30 分钟前
Go vs Java 的三阶段切换路线图
java·开发语言·golang
小L~~~42 分钟前
绿盟校招C++研发工程师一面复盘
c++·面试
毕设源码-钟学长1 小时前
【开题答辩全过程】以 基于Java的慕课点评网站为例,包含答辩的问题和答案
java·开发语言
小北方城市网1 小时前
分布式锁实战指南:从选型到落地,避开 90% 的坑
java·数据库·redis·分布式·python·缓存
深圳佛手1 小时前
使用java,怎么样高效地读取一个大文件(10g以上)?
java·开发语言
sheji34161 小时前
【开题答辩全过程】以 景点移动导游系统的设计与实现为例,包含答辩的问题和答案
java
毕设源码-赖学姐1 小时前
【开题答辩全过程】以 高校失物招领信息管理系统的设计与开发为例,包含答辩的问题和答案
java
xiaolyuh1231 小时前
【XXL-JOB】 GLUE模式 底层实现原理
java·开发语言·前端·python·xxl-job
ohoy1 小时前
RedisTemplate 使用之Zset
java·开发语言·redis