码迷,mamicode.com
首页 > 编程语言 > 详细

Java I/O总结(二)NIO

时间:2018-02-21 11:42:27      阅读:179      评论:0      收藏:0      [点我收藏+]

标签:多个   margin   数据类型   映射   span   sel   定义   lin   tor   

I/O的同步异步,阻塞非阻塞:

阻塞:当执行的操作所需的数据还没准备好时,线程进行等待

非阻塞:当数据还没准备好时,线程不等待

同步:执行操作,一直等操作执行完才向下执行

异步:执行操作,调用接口后不用等待,向下执行

常用的 read() write() 方法都是同步I/O

传统的I/O是阻塞式的。

问题在于:当操作所需的数据没有准备好,如数据没有到达,线程会一直等待。

为了解决这一问题,引入了NIO概念:同步非阻塞I/O.

NIO相当于定义一个调度器selector,把所有实现通信的信道channel注册到selector,由它调度各个信道的运行情况,实现各个信道不发生阻塞地传输。

Channel

FileChannelDatagramChannel(UDP)SocketChannel(TCP)ServerSocketChannel(TCP)

这些通道涵盖了UDP TCP 网络IO,以及文件IO

Buffer:(有三个参数,容量capacity,当前存储位置position,上界limit

  写模式下,limit等于capacity;读模式下,limit等于position

ByteBufferCharBufferDoubleBufferFloatBufferIntBufferLongBufferShortBuffer

这些Buffer覆盖了你能通过IO发送的基本数据类型:byte, short, int, long, float, double char

Java NIO 还有个 MappedByteBuffer,用于表示内存映射文件。

Selector(可以比为一个调度工具)

Selector允许单线程处理多个 Channel

用于向 buffer 提供数据或者读取 buffer 数据 ,buffer 对象的唯一接口。

1. 创建selectorchannel,把channel信道设为非阻塞模式

2. 绑定socket对象到channel

3. channel注册到selector

4. 调用selectorselectedKeys检查所有信道是否有需要的事情发生,如果有事情发生,返回所有的channel对象。

5. 通过信道,读取通信的数据,读取的是buffer


Java I/O总结(二)NIO

标签:多个   margin   数据类型   映射   span   sel   定义   lin   tor   

原文地址:http://blog.51cto.com/13580976/2072002

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!