JavaTM Platform
Standard Ed. 6

java.nio.channels.spi
クラス AbstractSelectableChannel

java.lang.Object
  上位を拡張 java.nio.channels.spi.AbstractInterruptibleChannel
      上位を拡張 java.nio.channels.SelectableChannel
          上位を拡張 java.nio.channels.spi.AbstractSelectableChannel
すべての実装されたインタフェース:
Closeable, Channel, InterruptibleChannel
直系の既知のサブクラス:
DatagramChannel, Pipe.SinkChannel, Pipe.SourceChannel, ServerSocketChannel, SocketChannel

public abstract class AbstractSelectableChannel
extends SelectableChannel

選択可能チャネルのベース実装クラスです。  

このクラスは、チャネルの登録、登録解除、クローズの処理を行うメソッドを定義します。このクラスは、このチャネルの現在のブロックモードと、現在の選択キーセットを管理します。また、SelectableChannel の仕様を実装するのに必要な同期処理をすべて実行します。このクラスに定義されている abstract protected メソッドの実装では、同じ操作を使用するほかのスレッドとの同期処理を行う必要はありません。

導入されたバージョン:
1.4

コンストラクタの概要
protected AbstractSelectableChannel(SelectorProvider provider)
          このクラスの新しいインスタンスを初期化します。
 
メソッドの概要
 Object blockingLock()
          configureBlocking メソッドと register メソッドが同期するオブジェクトを返します。
 SelectableChannel configureBlocking(boolean block)
          このチャネルのブロックモードを調整します。
protected  void implCloseChannel()
          現在のチャネルをクローズします。
protected abstract  void implCloseSelectableChannel()
          この選択可能チャネルをクローズします。
protected abstract  void implConfigureBlocking(boolean block)
          このチャネルのブロックモードを調整します。
 boolean isBlocking()
          このチャネル上の個々の入出力操作が前の入出力操作が完了するまでブロックされるかどうかを判断します。
 boolean isRegistered()
          現在このチャネルがセレクタに登録されているかどうかを判断します。
 SelectionKey keyFor(Selector sel)
          チャネルが指定されたセレクタに登録されていることを示すキーを取得します。
 SelectorProvider provider()
          このチャネルの作成元プロバイダを返します。
 SelectionKey register(Selector sel, int ops, Object att)
          このチャネルを指定されたセレクタに登録し、選択キーを返します。
 
クラス java.nio.channels.SelectableChannel から継承されたメソッド
register, validOps
 
クラス java.nio.channels.spi.AbstractInterruptibleChannel から継承されたメソッド
begin, close, end, isOpen
 
クラス java.lang.Object から継承されたメソッド
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 
インタフェース java.nio.channels.Channel から継承されたメソッド
close, isOpen
 

コンストラクタの詳細

AbstractSelectableChannel

protected AbstractSelectableChannel(SelectorProvider provider)
このクラスの新しいインスタンスを初期化します。

メソッドの詳細

provider

public final SelectorProvider provider()
このチャネルの作成元プロバイダを返します。

定義:
クラス SelectableChannel 内の provider
戻り値:
このチャネルの作成元プロバイダ

isRegistered

public final boolean isRegistered()
クラス SelectableChannel の記述:
現在このチャネルがセレクタに登録されているかどうかを判断します。新しく作成されたチャネルは登録されていません。  

キーの取り消しからチャネルの登録解除までの間に発生する必然的な遅延のため、キーをすべて取り消しても、しばらくの間チャネルの登録は解除されません。チャネルをクローズしたときも同様です。

定義:
クラス SelectableChannel 内の isRegistered
戻り値:
このチャネルが登録されている場合にかぎり true

keyFor

public final SelectionKey keyFor(Selector sel)
クラス SelectableChannel の記述:
チャネルが指定されたセレクタに登録されていることを示すキーを取得します。

定義:
クラス SelectableChannel 内の keyFor
戻り値:
前回このチャネルを指定されたセレクタに登録したとき返されたキー。現在このチャネルが指定されたセレクタに登録されていない場合は null

register

public final SelectionKey register(Selector sel,
                                   int ops,
                                   Object att)
                            throws ClosedChannelException
このチャネルを指定されたセレクタに登録し、選択キーを返します。  

このメソッドは、最初にこのチャネルがオープンしていることと、指定された初期対象セットが有効であることを確認します。  

このチャネルが指定されたセレクタに登録されている場合、その対象セットが指定された値に設定され、登録を示す選択キーが返されます。  

それ以外の場合、このチャネルは指定されたセレクタにまだ登録されていないので、適切なロックを保持した状態でセレクタの register メソッドが呼び出されます。結果として得られるキーは、返される前に、このチャネルのキーセットに追加されます。

定義:
クラス SelectableChannel 内の register
パラメータ:
sel - このチャネルの登録先セレクタ
ops - 結果として得られるキーの対象セット
att - 結果として得られるキーの添付。null の場合もある
戻り値:
このチャネルが指定されたセレクタに登録されていることを示すキー
例外:
ClosedChannelException - このチャネルがクローズしている場合

implCloseChannel

protected final void implCloseChannel()
                               throws IOException
現在のチャネルをクローズします。  

このメソッドは、AbstractInterruptibleChannel クラスで指定されています。 このメソッドは、close メソッドによって呼び出されたあと、このチャネルを実際にクローズする処理を行うために implCloseSelectableChannel メソッドを呼び出します。次に、このチャネルのキーをすべて取り消します。

定義:
クラス AbstractInterruptibleChannel 内の implCloseChannel
例外:
IOException - チャネルのクローズ中に入出力エラーが発生した場合

implCloseSelectableChannel

protected abstract void implCloseSelectableChannel()
                                            throws IOException
この選択可能チャネルをクローズします。  

このメソッドは、チャネルをクローズする実際の処理を実行するために close メソッドによって呼び出されます。このメソッドは、チャネルがまだクローズしていない場合にのみ呼び出され、2 回以上呼び出されることはありません。  

このメソッドの実装は、このチャネルに対する入出力操作の途中でブロックされるその他のスレッドを、例外をスローするか、通常の方法を使ってただちに終了させることになっています。

例外:
IOException

isBlocking

public final boolean isBlocking()
クラス SelectableChannel の記述:
このチャネル上の個々の入出力操作が前の入出力操作が完了するまでブロックされるかどうかを判断します。新しく作成されたチャネルは常にブロックモードです。  

このチャネルがクローズしている場合、このメソッドの戻り値は特定されません。

定義:
クラス SelectableChannel 内の isBlocking
戻り値:
このチャネルがブロックモードである場合にかぎり true

blockingLock

public final Object blockingLock()
クラス SelectableChannel の記述:
configureBlocking メソッドと register メソッドが同期するオブジェクトを返します。この機能は、特定のブロックモードを短時間保持する必要があるアダプタを実装する場合に便利です。

定義:
クラス SelectableChannel 内の blockingLock
戻り値:
ブロックモードのロックオブジェクト

configureBlocking

public final SelectableChannel configureBlocking(boolean block)
                                          throws IOException
このチャネルのブロックモードを調整します。  

指定されたブロックモードが現在のブロックモードと異なっている場合、このメソッドは、適切なロックを保持した状態で implConfigureBlocking メソッドを呼び出してモードを変更します。

定義:
クラス SelectableChannel 内の configureBlocking
パラメータ:
block - true の場合はこのチャネルがブロックモードになり、false の場合は非ブロックモードになる
戻り値:
この選択可能チャネル
例外:
ClosedChannelException - このチャネルがクローズしている場合
IOException - 入出力エラーが発生した場合

implConfigureBlocking

protected abstract void implConfigureBlocking(boolean block)
                                       throws IOException
このチャネルのブロックモードを調整します。  

このメソッドは、ブロックモードを変更する実際の処理を行うために、configureBlocking メソッドによって呼び出されます。このメソッドは、新しいモードが現在のモードと異なっている場合に限り呼び出されます。

例外:
IOException - 入出力エラーが発生した場合

JavaTM Platform
Standard Ed. 6

バグの報告と機能のリクエスト
さらに詳しい API リファレンスおよび開発者ドキュメントについては、Java SE 開発者用ドキュメントを参照してください。開発者向けの詳細な解説、概念の概要、用語の定義、バグの回避策、およびコード実例が含まれています。

Copyright 2009 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Documentation Redistribution Policy も参照してください。