NIO学习笔记

IO向NIO的转变:单线程IO(阻塞问题)->引入多线程,创建多个socket(性能浪费)-->引入线程池,进行IO相关操作再拿IO线程进行IO操作
Java NIO:可以非阻塞的使用IO


核心组成部分:Channels(通道),Buffers(缓冲区),Selectors(选择器);
其他组件,Pipe,FileLock
一.Channel

Channel和Buffer,所有IO在NIO中都从一个Channel开始,Channel有点像流,

NIO学习笔记-Channel笔记基础

二.Buffer

缓冲区,在内存中开启的一段连续空间(数组)0,用来临时存放数据,解决了BIO中无法针对某个点有针对性处理

NIO学习笔记-Buffer基础
三.Selector
Selector允许单线程处理多个Channel,如果要使用Selector,得向Selector注册Channel,然后调用select()方法.这个方法会一直阻塞到摸个注册的通道有事件就绪(包括新连接进来,数据接收等),一旦这个方法返回,线程就可以处理这个事件


NIO学习笔记--Selector基础

在NIO中虽然IO是非阻塞的,但selector()方法是阻塞的

四.不同的Channel

//TODO



资料来源:

NIO官方文档:http://tutorials.jenkov.com/java-nio/index.html

并发编程网:ifeve.com/overview/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值