1. Channeljava
Channel接口只提供了两个方法:socket
package java.nio.channels;
public interface Channel {
public boolean isOpen( );
public void close( ) throws IOException;
}
调用close()可能会形成阻塞,若是同一个Channel上屡次调用close()也没有什么问题,若是第一次调用阻塞了,后续的调用都会阻塞,知道第一次调用关闭,测试
此时,后续的调用将不执行任何操做,立刻返回。spa
2. ByteChannel线程
public interface ReadableByteChannel extends Channel { public int read (ByteBuffer dst) throws IOException; } public interface WritableByteChannel extends Channel { public int write (ByteBuffer src) throws IOException; }
//ByteChannel自己没有新增任何方法,继承了可读和可写的接口 public interface ByteChannel extends ReadableByteChannel, WritableByteChannel {
}
基本上全部的file和socket都实现了这三个接口,因此file和socket通道对象都是双向的,通常来讲socket是双向的,可是file就不是了。code
从FileInputStream对象的getChannel( )方法获取的FileChannel对象是只读的,尽管获取到的Channel也是实现了write方法,对象
FileChannel实现ByteChannel接口。在这样一个通道上调用write( )方法将抛出未经检查的NonWritableChannelException异常,blog
由于FileInputStream对象老是以read-only的权限打开文件。继承
3 对于线程中断异常的解释接口
若是一个通道实现InterruptibleChannel接口,它的行为如下述语义为准:
若是一个线程在一个通道上被阻塞而且同时被中断(由调用该被阻塞线程的interrupt( )方法的另外一个线程中断),那么该通道将被关闭,
该被阻塞线程也会产生一个ClosedByInterruptException异常。
此外,假如一个线程的中断状态被设置,而且该线程试图访问一个通道,那么这个通道将当即被关闭,同时将抛出相同的ClosedByInterruptException异常。
线程的中断状态在线程的interrupt( )方法被调用时会被设置。咱们可使用isInterrupted( )来测试某个线程当前的中断状态。
当前线程的中断状态能够经过调用静态的Thread.interrupted( )方法清除。
不要将在Channels上休眠的中断线程同在Selectors上休眠的中断线程混淆。前者会关闭通道,然后者则不会。
不过,若是您的线程在Selector上休眠时被中断,那它的中断状态将会被设置。假设那个线程接着又访问一个Channel,则该通道会被关闭。