所有的IO在NIO 中都从一个Channel
开始。Channel
有点象流。 数据可以从Channel
读到Buffer
中,也可以从Buffer
写到Channel
中。
Channel的主要类型
NIO.pngchannel主要有四种类型:
FileChannel
DatagramChannel
SocketChannel
ServerSocketChannel
这四种类型分别涵盖了文件IO、UDP和TCP网络IO。
- FileChannel 从文件中读写数据。
- DatagramChannel 能通过UDP读写网络中的数据。
- SocketChannel 能通过TCP读写网络中的数据。
- ServerSocketChannel可以监听新进来的TCP连接,像Web服务器那样。对每一个新进来的连接都会创建一个SocketChannel。
Java NIO的通道类似流,但又有些不同:
- 既可以从通道中读取数据,又可以写数据到通道(即Channel是双向的)。但流的读写通常是单向的。
- 通道可以异步地读写。(Channel可以异步读写,而非一定是异步读写)
- 通道中的数据总是要先读到一个Buffer,或者总是要从一个Buffer中写入。
网友评论