`

java.nio.channels.SocketChannel

    博客分类:
  • APIs
阅读更多
public abstract class
SocketChannel
extends AbstractSelectableChannel
implements ByteChannel GatheringByteChannel ScatteringByteChannel
java.lang.Object
   ? java.nio.channels.spi.AbstractInterruptibleChannel
   ? java.nio.channels.SelectableChannel
   ? java.nio.channels.spi.AbstractSelectableChannel
   ? java.nio.channels.SocketChannel

Class Overview

SocketChannel是一个可选的通道,通道提供一个连接socket的局部抽象流。
socket()方法返回相关的socket实例。
当使用open()方法打开channel时,socket channel处于打开但并未连接状态。
当调用connect(SocketAddress)方法建立连接后,通道将一直连接着直到被关闭。
如果连接对象connection没有被锁定,可以用connect(SocketAddress) 来初始化connection对象,然后用finishConnect()进行建立连接的最后一步。
isConnectionPending()可以查看连接对象是否被锁住。isConnected()可以查看是否连接到socket了。
channel的输入端和输出端可以被独立地、异步地关闭,而不需要关闭channel。
shutdownInput方法用于channel的输入端,因此读操作返回-1,也就是流的结束。
shutdownInput方法用于channel的输入端,读操作返回-1,也就是流的结束。
如果另外一个线程正在进行读操作,这时候发生了shutdown事件,读操作将被终止并返回流的结束。
shutdownOutput方法用于channel的输出端。
此时如果另外一个线程正在进行写读操作,則会抛出ClosedChannelException异常.
而如果输出流被關閉,此时有线程在进行写操作,那么会抛出AsynchronousCloseException异常.
注意,Socket是线程安全的.也就是说任一时刻,不能有多于一条线程在进行读或著写操作.
connect(SocketAddress)和finishConnect() 方法是同步互斥的,所以当这两个方法正在执行时,
读写操作将被挂起.

Summary

Protected Constructors

SocketChannel(SelectorProvider selectorProvider)
Constructs a new SocketChannel.
构造一个新的SocketChannel。

Public Methods

abstract boolean connect(SocketAddress address)
Connects this channel's socket with a remote address.
将channel与远程地址相连。

abstract boolean finishConnect()
Completes the connection process initiated by a call of connect(SocketAddress).
connect(socketAddress)方法建立链接,由该方法完成。

abstract boolean isConnected()
Indicates whether this channel's socket is connected.
判断链接是否已经建立。

abstract boolean isConnectionPending()
Indicates whether this channel's socket is still trying to connect.
判断channel的socket是否仍在尝试建立连接。

static SocketChannel open()
Creates an open and unconnected socket channel.
创建一个打开但是未连接的socket channel。

static SocketChannel open(SocketAddress address)
Creates a socket channel and connects it to a socket address.
创建一个socket channel并连接到指定的远程地址。

abstract int read(ByteBuffer target)
Reads bytes from this socket channel into the given buffer.
从socket channel读取数据到指定的缓冲区。

abstract long read(ByteBuffer[] targets, int offset, int length)
Reads bytes from this socket channel into a subset of the given buffers.
从socket channel的offset处读取length个字节,存储到targets。

synchronized final long read(ByteBuffer[] targets)
Reads bytes from this socket channel and stores them in the specified array of buffers.
从socket channel读取字节数据,存储到指定的缓冲区数组。

abstract Socket socket()
Returns the socket assigned to this channel, which does not declare any public methods that are not declared in Socket.
返回分配给该channel的socket。

final int validOps()
Gets the valid operations of this channel.
返回可用操作。

/* 写操作与读操作类似,不赘述。 */
synchronized final long write(ByteBuffer[] sources)
Writes bytes from all the given byte buffers to this socket channel.

abstract long write(ByteBuffer[] sources, int offset, int length)
Attempts to write a subset of the given bytes from the buffers to this socket channel.

abstract int write(ByteBuffer source)
Writes bytes from the given byte buffer to this socket channel.

[Expand]
Inherited Methods
From class java.nio.channels.spi.AbstractSelectableChannel
From class java.nio.channels.SelectableChannel
From class java.nio.channels.spi.AbstractInterruptibleChannel
From class java.lang.Object
From interface java.io.Closeable
From interface java.nio.channels.Channel
From interface java.nio.channels.GatheringByteChannel
From interface java.nio.channels.InterruptibleChannel
From interface java.nio.channels.ReadableByteChannel
From interface java.nio.channels.ScatteringByteChannel
From interface java.nio.channels.WritableByteChannel

Protected Constructors

protected SocketChannel (SelectorProvider selectorProvider)
Since: API Level 1
Constructs a new SocketChannel.
Parameters
selectorProvider an instance of SelectorProvider.


Public Methods

public abstract boolean connect (SocketAddress address)
Since: API Level 1
Connects this channel's socket with a remote address.
If this channel is blocking, this method will suspend until connecting is finished or an I/O exception occurrs. If the channel is non-blocking, this method will return true if the connection is finished at once or return false when the connection must be finished later by calling finishConnect().
This method can be called at any moment and can block other read and write operations while connecting. It executes the same security checks as the connect method of the Socket class.
将channel连接到远程地址。
如果channel被阻塞了。该方法将被挂起指定连接完成或者出现IO异常。
如果channel没有被阻塞,当连接完成时方法返回true;如果需要调用finishConnect()方法完成连接,则返回false。
该方法可以在任何时刻被调用,并且在进行连接时会阻塞所有读和写操作。
它执行的安全检查与connect方法相同。

Parameters
address the address to connect with.
Returns
true if the connection is finished, false otherwise.
Throws
AlreadyConnectedException if the channel is already connected.
ConnectionPendingException a non-blocking connecting operation is already executing on this channel.
ClosedChannelException if this channel is closed.
AsynchronousCloseException if this channel is closed by another thread while this method is executing.
ClosedByInterruptException if another thread interrupts the calling thread while this operation is in progress.
The calling thread will have the interrupt state set and this channel will be closed.
UnresolvedAddressException if the address is not resolved.
UnsupportedAddressTypeException if the address type is not supported.
SecurityException if there is a security manager and it denies the access of address.
IOException if an I/O error occurs.

public abstract boolean finishConnect ()
Since: API Level 1
Completes the connection process initiated by a call of connect(SocketAddress).
This method returns true if the connection is finished already and returns false if the channel is non-blocking and the connection is not finished yet.
If this channel is in blocking mode, this method will suspend and return true when the connection is finished. It closes this channel and throws an exception if the connection fails.
This method can be called at any moment and it can block other read and write operations while connecting.
该方法返回true,如果连接已经完成了;返回false,如果channel处于非阻塞状态并且连接尚未建立。
如果channel处于阻塞模式,该方法将被挂起;在完成连接后返回true。如果连接失败,则关闭channel并且抛出异常。
该方法可以在任意时刻被调用,执行连接操作使会阻塞其它所有读和写操作。
Returns
true if the connection is successfully finished, false otherwise.
Throws
NoConnectionPendingException if the channel is not connected and the connection process has not been initiated.
ClosedChannelException if this channel is closed.
AsynchronousCloseException if this channel is closed by another thread while this method is executing.
ClosedByInterruptException if another thread interrupts the calling thread while this operation is in progress.
The calling thread has the interrupt state set, and this channel is closed.
IOException if an I/O error occurs.

public abstract boolean isConnected ()
Since: API Level 1
Indicates whether this channel's socket is connected.
Returns
true if this channel's socket is connected, false otherwise.

public abstract boolean isConnectionPending ()
Since: API Level 1
Indicates whether this channel's socket is still trying to connect.
Returns
true if the connection is initiated but not finished; false otherwise.
连接已经初始化但是未完成,返回true;
否则返回false。

public static SocketChannel open ()
Since: API Level 1
Creates an open and unconnected socket channel.
This channel is created by calling openSocketChannel() of the default SelectorProvider instance.
Returns
the new channel which is open but unconnected.
Throws
IOException if an I/O error occurs.

public static SocketChannel open (SocketAddress address)
Since: API Level 1
Creates a socket channel and connects it to a socket address.
This method performs a call to open() followed by a call to connect(SocketAdress).
Parameters
address the socket address to be connected to.
Returns
the new connected channel.
Throws
AsynchronousCloseException if this channel is closed by another thread while this method is executing.
ClosedByInterruptException if another thread interrupts the calling thread while this operation is executing.
The calling thread will have the interrupt state set and the channel will be closed.
SecurityException if there is a security manager and it denies the access of address.
UnresolvedAddressException if the address is not resolved.
UnsupportedAddressTypeException if the address type is not supported.
IOException if an I/O error occurs.


/* 读写操作的详细文档请参照java.nio.channels.ServerSocketChannel.java */
public abstract int read (ByteBuffer target)
Since: API Level 1
Reads bytes from this socket channel into the given buffer.
The maximum number of bytes that will be read is the remaining number of bytes in the buffer when the method is invoked. The bytes will be copied into the buffer starting at the buffer's current position.
The call may block if other threads are also attempting to read from this channel.
Upon completion, the buffer's position is set to the end of the bytes that have been read. The buffer's limit is not changed.
Parameters
target the byte buffer to receive the bytes.
Returns
the number of bytes actually read.
Throws
AsynchronousCloseException if another thread closes the channel during the read.
NotYetConnectedException if this channel is not yet connected.
ClosedByInterruptException if another thread interrupts the calling thread while this operation is in progress.
The interrupt state of the calling thread is set and the channel is closed.
ClosedChannelException if this channel is closed.
IOException if another I/O error occurs.
See Also
read(java.nio.ByteBuffer)

public abstract long read (ByteBuffer[] targets, int offset, int length)
Since: API Level 1
Reads bytes from this socket channel into a subset of the given buffers. This method attempts to read all remaining() bytes from length byte buffers, in order, starting at targets[offset]. The number of bytes actually read is returned.
If a read operation is in progress, subsequent threads will block until the read is completed and will then contend for the ability to read.
Parameters
targets the array of byte buffers into which the bytes will be copied.
offset the index of the first buffer to store bytes in.
length the maximum number of buffers to store bytes in.
Returns
the number of bytes actually read.
Throws
AsynchronousCloseException if this channel is closed by another thread during this read operation.
ClosedByInterruptException if another thread interrupts the calling thread while this operation is in progress.
The interrupt state of the calling thread is set and the channel is closed.
ClosedChannelException if this channel is closed.
IndexOutOfBoundsException if offset < 0 or length < 0, or if offset + length is greater than the size of targets.
IOException if another I/O error occurs.
NotYetConnectedException if this channel is not yet connected.
See Also
read(java.nio.ByteBuffer[], int, int)

public final synchronized long read (ByteBuffer[] targets)
Since: API Level 1
Reads bytes from this socket channel and stores them in the specified array of buffers. This method attempts to read as many bytes as can be stored in the buffer array from this channel and returns the number of bytes actually read.
If a read operation is in progress, subsequent threads will block until the read is completed and will then contend for the ability to read.
Calling this method is equivalent to calling read(targets, 0, targets.length);
Parameters
targets the array of byte buffers into which the bytes will be copied.
Returns
the number of bytes actually read.
Throws
AsynchronousCloseException if this channel is closed by another thread during this read operation.
ClosedByInterruptException if another thread interrupts the calling thread while this operation is in progress.
The interrupt state of the calling thread is set and the channel is closed.
ClosedChannelException if this channel is closed.
IOException if another I/O error occurs.
NotYetConnectedException if this channel is not yet connected.

public abstract Socket socket ()
Since: API Level 1
Returns the socket assigned to this channel, which does not declare any public methods that are not declared in Socket.
Returns
the socket assigned to this channel.
public final int validOps ()
Since: API Level 1
Gets the valid operations of this channel. Socket channels support connect, read and write operation, so this method returns SelectionKey.OP_CONNECT | SelectionKey.OP_READ | SelectionKey.OP_WRITE.
Returns
the operations supported by this channel.
See Also
validOps()

public final synchronized long write (ByteBuffer[] sources)
Since: API Level 1
Writes bytes from all the given byte buffers to this socket channel.
Calling this method is equivalent to calling write(sources, 0, sources.length);
Parameters
sources the buffers containing bytes to write.
Returns
the number of bytes actually written.
Throws
AsynchronousCloseException if this channel is closed by another thread during this write operation.
ClosedByInterruptException if another thread interrupts the calling thread while this operation is in progress.
The interrupt state of the calling thread is set and the channel is closed.
ClosedChannelException if this channel is closed.
IOException if another I/O error occurs.
NotYetConnectedException if this channel is not yet connected.
See Also

write(java.nio.ByteBuffer[])
public abstract long write (ByteBuffer[] sources, int offset, int length)
Since: API Level 1
Attempts to write a subset of the given bytes from the buffers to this socket channel. This method attempts to write all remaining() bytes from length byte buffers, in order, starting at sources[offset]. The number of bytes actually written is returned.
If a write operation is in progress, subsequent threads will block until the write is completed and then contend for the ability to write.
Parameters
sources the array of byte buffers that is the source for bytes written to this channel.
offset the index of the first buffer in buffers to get bytes from.
length the number of buffers to get bytes from.
Returns
the number of bytes actually written to this channel.
Throws
AsynchronousCloseException if this channel is closed by another thread during this write operation.
ClosedByInterruptException if another thread interrupts the calling thread while this operation is in progress.
The interrupt state of the calling thread is set and the channel is closed.
ClosedChannelException if this channel is closed.
IndexOutOfBoundsException if offset < 0 or length < 0, or if offset + length is greater than the size of sources.
IOException if another I/O error occurs.
NotYetConnectedException if this channel is not yet connected.
See Also
write(java.nio.ByteBuffer[], int, int)

public abstract int write (ByteBuffer source)
Since: API Level 1
Writes bytes from the given byte buffer to this socket channel. The maximum number of bytes that are written is the remaining number of bytes in the buffer when this method is invoked. The bytes are taken from the buffer starting at the buffer's position.
The call may block if other threads are also attempting to write to the same channel.
Upon completion, the buffer's position is updated to the end of the bytes that have been written. The buffer's limit is not changed.
Parameters
source the byte buffer containing the bytes to be written.
Returns
the number of bytes actually written.
Throws
AsynchronousCloseException if another thread closes the channel during the write.
ClosedByInterruptException if another thread interrupts the calling thread while this operation is in progress.
The interrupt state of the calling thread is set and the channel is closed.
ClosedChannelException if the channel was already closed.
IOException if another I/O error occurs.
NotYetConnectedException if this channel is not connected yet.
See Also
write(java.nio.ByteBuffer)






分享到:
评论

相关推荐

    Java.NIO资源下载资源下载

    - **Channels 工具类**:介绍了 Java NIO 提供的一些工具类,用于简化 Channel 的使用。 #### 3. Selector(选择器) - **Selector 基础**:介绍了 Selector 的基本概念及工作原理。 - **使用 SelectionKey**:...

    java NIO.zip

    Java NIO支持多种类型的通道,包括文件通道(FileChannel)、套接字通道(SocketChannel)和服务器套接字通道(ServerSocketChannel)等。通道可以同时进行读写操作,并且可以实现异步读写。 2. **缓冲区(Buffers...

    nio.rar_NIO_NIO-socket_java nio_java 实例_java.nio

    在Java NIO中,数据是以通道(Channels)和缓冲区(Buffers)的形式进行传输,而不是直接通过流。这种设计使得NIO能够同时处理多个输入/输出操作,从而实现多路复用。 标题“nio.rar_NIO_NIO-socket_java nio_java ...

    java.nio API详解

    2. `java.nio.channels`:这个包包含一系列Channel接口和它们的实现,如FileChannel、SocketChannel等。Channel代表了一个开放的I/O资源,数据可以通过Channel进行传输。Selector是这个包中的另一个重要组件,它允许...

    基于java的BIO、NIO、AIO通讯模型代码实现

    关键类包括:`java.nio.channels.Selector`、`java.nio.channels.ServerSocketChannel`、`java.nio.channels.SocketChannel`,以及缓冲区类如`ByteBuffer`。 **3. 埼于Java的AIO(Asynchronous I/O)** AIO,也...

    java NIO详细教程

    socketChannel.register(selector, SelectionKey.OP_READ); } else if (key.isReadable()) { // 读取数据 SocketChannel socketChannel = (SocketChannel) key.channel(); ByteBuffer buffer = ByteBuffer....

    使用Java NIO编写高性能的服务器.doc

    import java.nio.channels.SocketChannel; import java.nio.charset.Charset; import java.nio.charset.CharsetDecoder; import java.util.Iterator; /** 测试文件下载的NIOServer */ public class NIOServer { ...

    nio socket编程java代码示例,客户端发送消息,服务端接收

    SocketChannel client = SocketChannel.open(); client.connect(new InetSocketAddress("localhost", 8000)); ByteBuffer buffer = ByteBuffer.allocate(1024); buffer.put("Hello, Server!".getBytes()); ...

    自己写的Java NIO 同步不阻塞IO操作

    - `java.nio.channels.SocketChannel`:用于客户端进行网络通信,可以通过`open()`方法创建,然后连接到服务器的套接字地址。 - `java.nio.channels.ServerSocketChannel`:用于服务器端,可以监听新的连接请求。 - ...

    The_Study_about_Java.nio.rar_java nio

    1. **通道(Channels)**:Java NIO中的通道类似于流,但它们是双向的,可以读写数据。常见的通道类有FileChannel、SocketChannel、ServerSocketChannel和DatagramChannel。 2. **缓冲区(Buffers)**:缓冲区是...

    java nio Selector的使用-客户端

    Selector是Java NIO中的核心组件之一,它允许单个线程处理多个通道(channels)的读写事件,极大地提高了服务器的并发能力。本篇文章将深入探讨如何在Java NIO中使用Selector处理客户端的I/O请求。 首先,我们需要...

    Apress.Pro.Java.7.NIO.2.2011

    Java NIO提供了多种类型的通道,如FileChannel、SocketChannel、ServerSocketChannel等,它们分别对应于文件、套接字和服务器套接字操作。 3. **缓冲区(Buffers)**:缓冲区是数据存储的容器,它在读写操作中起到...

    java NIO 开发技术

    import java.nio.channels.SocketChannel; public class NIOServer { public static void main(String[] args) throws IOException { ServerSocketChannel serverSocket = ServerSocketChannel.open(); ...

    tcp nio basics

    SocketChannel client = SocketChannel.open(new InetSocketAddress("localhost", 8080)); client.configureBlocking(false); Selector selector = Selector.open(); client.register(selector, SelectionKey.OP...

    java org.apache.http.nio jar包

    1. **Java NIO**:Java NIO(New I/O)是在Java 1.4中引入的,与传统的阻塞I/O(BIO)模型不同,NIO提供了一种新的方式来处理I/O操作。它支持通道(Channels)和选择器(Selectors),能够实现多路复用,即单个线程...

    Java NIO 聊天室 JSwing

    SocketChannel channel = SocketChannel.open(); // 设置通道为非阻塞 channel.configureBlocking(false); // 获得一个通道管理器 this.selector = Selector.open(); // 客户端连接服务器,其实方法执行...

    Java NIO原理分析及代码实例

    import java.nio.channels.SocketChannel; public class NIOServer { public static void main(String[] args) throws IOException { ServerSocketChannel serverSocket = ServerSocketChannel.open(); ...

    Java NIO原理 图文分析及代码实现

    import java.nio.channels.ServerSocketChannel; import java.nio.channels.SocketChannel; import java.util.Iterator; /** * NIO服务端 * @author 小路 */ public class NIOServer { // 通道管理器 private ...

    java的ServerSocketChannel与SocketChannel的使用

    在客户端,通过`java.nio.channels.SocketChannel.open()`获取。 2. 配置为非阻塞:`SocketChannel`默认是阻塞模式,可以调用`configureBlocking(false)`将其设置为非阻塞模式。 3. 连接服务器:在客户端,调用`...

Global site tag (gtag.js) - Google Analytics