- Java NIO Tutorial
- Java NIO - Home
- Java NIO - Overview
- Java NIO - Environment Setup
- Java NIO vs JAVA IO
- Java NIO - Channels
- Java NIO - File Channel
- Java NIO - DataGram Channel
- Java NIO - Socket Channel
- Java NIO - Server Socket Channel
- Java NIO - Scatter
- Java NIO - Gather
- Java NIO - Buffer
- Java NIO - Selector
- Java NIO - Pipe
- Java NIO - Path
- Java NIO - File
- Java NIO - AsynchronousFileChannel
- Java NIO - CharSet
- Java NIO - FileLock
- Java NIO Useful Resources
- Java NIO - Quick Guide
- Java NIO - Useful Resources
- Java NIO - Discussion
Java NIO - 数据报通道
Java NIO 数据报用作通道,可以通过无连接协议发送和接收 UDP 数据包。默认情况下,数据报通道是阻塞的,但可以在非阻塞模式下使用。为了使其成为非阻塞,我们可以使用 configureBlocking( false) 方法。DataGram 通道可以通过调用其名为open()的静态方法之一来打开,该方法也可以将 IP 地址作为参数,以便可以用于多播。
与 FileChannel 类似的数据报通道默认情况下不会连接,为了使其连接,我们必须显式调用其 connect() 方法。但是,数据报通道不需要连接,以便在必须连接时使用发送和接收方法为了使用读取和写入方法,因为这些方法不接受或返回套接字地址。
我们可以通过调用其isConnected()方法来检查数据报通道的连接状态。一旦连接,数据报通道将保持连接状态,直到断开或关闭。数据报通道是线程安全的,支持多线程和并发。
数据报通道的重要方法
bind(SocketAddress local) - 此方法用于将数据报通道的套接字绑定到本地地址,该地址作为此方法的参数提供。
connect(SocketAddress remote) - 此方法用于将套接字连接到远程地址。
connect() - 此方法用于断开与远程地址的套接字。
getRemoteAddress() - 此方法返回通道套接字连接的远程位置的地址。
isConnected() - 正如已经提到的,此方法返回数据报通道的连接状态,即是否已连接。
open() 和 open(ProtocolFamily family) - Open 方法用于为单个地址打开数据报通道,而参数化 open 方法用于为表示为协议族的多个地址打开通道。
read(ByteBuffer dst) - 此方法用于通过数据报通道从给定缓冲区读取数据。
receive(ByteBuffer dst) - 此方法用于通过此通道接收数据报。
send(ByteBuffer src, SocketAddress target) - 此方法用于通过此通道发送数据报。
例子
以下示例展示了如何从 Java NIO DataGramChannel 发送数据。
服务器:DatagramChannelServer.java
import java.io.IOException; import java.net.InetSocketAddress; import java.net.SocketAddress; import java.nio.ByteBuffer; import java.nio.channels.DatagramChannel; public class DatagramChannelServer { public static void main(String[] args) throws IOException { DatagramChannel server = DatagramChannel.open(); InetSocketAddress iAdd = new InetSocketAddress("localhost", 8989); server.bind(iAdd); System.out.println("Server Started: " + iAdd); ByteBuffer buffer = ByteBuffer.allocate(1024); //receive buffer from client. SocketAddress remoteAdd = server.receive(buffer); //change mode of buffer buffer.flip(); int limits = buffer.limit(); byte bytes[] = new byte[limits]; buffer.get(bytes, 0, limits); String msg = new String(bytes); System.out.println("Client at " + remoteAdd + " sent: " + msg); server.send(buffer,remoteAdd); server.close(); } }
输出
Server Started: localhost/127.0.0.1:8989
客户端:DatagramChannelClient.java
import java.io.IOException; import java.net.InetSocketAddress; import java.net.SocketAddress; import java.nio.ByteBuffer; import java.nio.channels.DatagramChannel; public class DatagramChannelClient { public static void main(String[] args) throws IOException { DatagramChannel client = null; client = DatagramChannel.open(); client.bind(null); String msg = "Hello World!"; ByteBuffer buffer = ByteBuffer.wrap(msg.getBytes()); InetSocketAddress serverAddress = new InetSocketAddress("localhost", 8989); client.send(buffer, serverAddress); buffer.clear(); client.receive(buffer); buffer.flip(); client.close(); } }
输出
运行客户端将在服务器上打印以下输出。
Server Started: localhost/127.0.0.1:8989 Client at /127.0.0.1:64857 sent: Hello World!