AutoCloseable
, Channel
, Closeable
AbstractInterruptibleChannel
, AbstractSelectableChannel
, DatagramChannel
, FileChannel
, Pipe.SinkChannel
, Pipe.SourceChannel
, SctpChannel
, SctpMultiChannel
, SctpServerChannel
, SelectableChannel
, ServerSocketChannel
, SocketChannel
public interface InterruptibleChannel extends Channel
A channel that implements this interface is asynchronously closeable: If a thread is blocked in an I/O operation on an interruptible channel then another thread may invoke the channel's close
method. This will cause the blocked thread to receive an AsynchronousCloseException
.
A channel that implements this interface is also interruptible: If a thread is blocked in an I/O operation on an interruptible channel then another thread may invoke the blocked thread's interrupt
method. This will cause the channel to be closed, the blocked thread to receive a ClosedByInterruptException
, and the blocked thread's interrupt status to be set.
If a thread's interrupt status is already set and it invokes a blocking I/O operation upon a channel then the channel will be closed and the thread will immediately receive a ClosedByInterruptException
; its interrupt status will remain set.
A channel supports asynchronous closing and interruption if, and only if, it implements this interface. This can be tested at runtime, if necessary, via the instanceof
operator.
Modifier and Type | Method | Description |
---|---|---|
void |
close() |
Closes this channel. |
void close() throws IOException
Any thread currently blocked in an I/O operation upon this channel will receive an AsynchronousCloseException
.
This method otherwise behaves exactly as specified by the Channel
interface.
close
in interface AutoCloseable
close
in interface Channel
close
in interface Closeable
IOException
- If an I/O error occurs
© 1993, 2023, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/en/java/javase/21/docs/api/java.base/java/nio/channels/InterruptibleChannel.html