12
Java NIO 简明教程 之 Java NIO 套接字通道(SocketChannel)
在 Java NIO 体系中,SocketChannel 是用于 TCP 网络连接的套接字接口,相当于 Java 网络编程中的 Socket 套接字接口。创建 SocketChannel 主要有两种方式,如下:
在 Java NIO 体系中,SocketChannel 是用于 TCP 网络连接的套接字接口,相当于 Java 网络编程中的 Socket 套接字接口。创建 SocketChannel 主要有两种方式,如下:
Java NIO 中的 FileChannel 是用于连接文件的通道(Channel)。通过 FileChannel 可以读、写文件的数据。Java NIO 的 FileChannel 是相对标准 Java IO API 的可选接口。
FileChannel 不可以设置为非阻塞模式,他只能在阻塞模式下运行。
选择器(Selector) 是 Java NIO 中用于检查一个或多个NIO Channel 状态是否处于可读、可写的组件。如此可以实现单线程管理多个 channel,从而可以管理多个网络链接。
在 Java NIO 中你可以从一个通道向另一个通道直接传输数据,如果一个 channel 是 FileChannel 类型的,那么他可以直接把数据传输到另一个 channel。逐个特性得益于FileChannel 类包含的 transferTo() 和 transferFrom() 两个方法。
Java NIO 内置了scatter/gather(分散/聚合)的支持,分散/聚合时通过通道(Channel)读写数据的两个概念。
分散读(Scattering read)是指从通道(Channel)中读取操作时将读取的数据写入多个缓冲区(Buffer)中,也就是 Scatter 代表了数据从通道(Channel)到多个缓冲区(Buffer)的过程。
Java NIO Buffers 和 NIO Channel 一起使用。正如你所知,数据从通道(channel)中读取到缓冲区(buffers),或从缓冲区(buffer)把数据写入到通道(channels) .
本文是基于《Java 开发手册》 1.5.0 华山版整理而来,《Java 开发手册》的前身是阿里巴巴集团技术团队推出的
《阿里巴巴Java开发手册》以及《码出高效:Java开发手册》,经历了多次大规模一线实战的检验及不断完善,公开到业界后,众多社区开发者踊跃参与,共同打磨完善,系统化地整理成册。
Java NIO Channels 和 流(Streams)非常相似,但还是有一些区别: