NIO总结与IO流的区别

本文详细解析了NIO(同步非阻塞I/O)与传统IO(同步阻塞I/O)的区别,包括它们的工作原理、如何实现以及应用场景。介绍了NIO的面向缓冲区特性,并通过具体的步骤展示了如何使用Selector来管理多个I/O操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

NIO同步和异步的区别:

同步和异步都是基于应用程序和操作系统。

同步:应用程序直接参与IO读写,所以是阻塞的,需要等待IO完成。

异步:IO读写交给操作系统。非阻塞。

NIO(同步非阻塞):面向缓冲区,

IO:面向流,(阻塞的 浪费性能)

NIO:主要是通过selector选择器管理所有的IO事件,服务端为例:首先需要serverSoketChannel.open();获得一个channel然后通过channel.configureBlocking(false);设置非阻塞再通过channel.socket();获取一个Serversocket,然后通过bing()绑定端口,后打开选择器 selector.open();通过channel.register(selector,key);注册通道。后通过selector.select();监听key.

IO流:字节流是读到一个就返回一个,几乎所有文件都可以读取,字符流是只能读取字符,读文本优先用字符流。

字节流(BufferedRead,BufferedWrite)

字符流(BufferedInputStream,BufferedOutStream)


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值