首页 > 代码库 > 一 NIO的概念
一 NIO的概念
Java NIO由下列几个核心部分组成:
- Channels(通道)
- Buffers(缓冲区)
- Asynchronous IO(异步IO)
Channel 和 Buffer
基本上所有的IO在NIO中都是从一个Channel开始,Channel有点像流。数据可以从Channel读到Buffer中,也可以从Buffer写到Channel中
Channel的实现类
- FileChannel
- DatagramChannel
- SocketChannel
- ServerSocketChannel
Buffer的实现
- ByteBuffer
- CharBuffer
- DoubleBuffer
- FloatBuffer
- IntBuffer
- LongBuffer
- ShortBuffer
Selector
Selector允许单线程处理多个Channel。如果你的应用打开了多个连接(通道),但每个连接的流量都很低,使用Selector就会很方便。
要使用Selector注册Channel,就得向Selector注册Channel,然后调用它的select()方法。这个方法会一直阻塞到某个注册的通道有事件就绪。一旦这个方法返回,线程就可以处理这些事件。
转载自并发编程网 – ifeve.com
一 NIO的概念
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。