|
JavaTM Platform Standard Ed. 6 |
|||||||||
前のクラス 次のクラス | フレームあり フレームなし | |||||||||
概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド |
java.lang.Object java.nio.channels.spi.AbstractInterruptibleChannel java.nio.channels.SelectableChannel java.nio.channels.spi.AbstractSelectableChannel
public abstract class AbstractSelectableChannel
選択可能チャネルのベース実装クラスです。
このクラスは、チャネルの登録、登録解除、クローズの処理を行うメソッドを定義します。このクラスは、このチャネルの現在のブロックモードと、現在の選択キーセットを管理します。また、SelectableChannel
の仕様を実装するのに必要な同期処理をすべて実行します。このクラスに定義されている abstract protected メソッドの実装では、同じ操作を使用するほかのスレッドとの同期処理を行う必要はありません。
コンストラクタの概要 | |
---|---|
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 |
コンストラクタの詳細 |
---|
protected AbstractSelectableChannel(SelectorProvider provider)
メソッドの詳細 |
---|
public final SelectorProvider provider()
SelectableChannel
内の provider
public final boolean isRegistered()
SelectableChannel
の記述:キーの取り消しからチャネルの登録解除までの間に発生する必然的な遅延のため、キーをすべて取り消しても、しばらくの間チャネルの登録は解除されません。チャネルをクローズしたときも同様です。
SelectableChannel
内の isRegistered
public final SelectionKey keyFor(Selector sel)
SelectableChannel
の記述:
SelectableChannel
内の keyFor
public final SelectionKey register(Selector sel, int ops, Object att) throws ClosedChannelException
このメソッドは、最初にこのチャネルがオープンしていることと、指定された初期対象セットが有効であることを確認します。
このチャネルが指定されたセレクタに登録されている場合、その対象セットが指定された値に設定され、登録を示す選択キーが返されます。
それ以外の場合、このチャネルは指定されたセレクタにまだ登録されていないので、適切なロックを保持した状態でセレクタの register
メソッドが呼び出されます。結果として得られるキーは、返される前に、このチャネルのキーセットに追加されます。
SelectableChannel
内の register
sel
- このチャネルの登録先セレクタops
- 結果として得られるキーの対象セットatt
- 結果として得られるキーの添付。null の場合もある
ClosedChannelException
- このチャネルがクローズしている場合protected final void implCloseChannel() throws IOException
このメソッドは、AbstractInterruptibleChannel
クラスで指定されています。 このメソッドは、close
メソッドによって呼び出されたあと、このチャネルを実際にクローズする処理を行うために implCloseSelectableChannel
メソッドを呼び出します。次に、このチャネルのキーをすべて取り消します。
AbstractInterruptibleChannel
内の implCloseChannel
IOException
- チャネルのクローズ中に入出力エラーが発生した場合protected abstract void implCloseSelectableChannel() throws IOException
このメソッドは、チャネルをクローズする実際の処理を実行するために close
メソッドによって呼び出されます。このメソッドは、チャネルがまだクローズしていない場合にのみ呼び出され、2 回以上呼び出されることはありません。
このメソッドの実装は、このチャネルに対する入出力操作の途中でブロックされるその他のスレッドを、例外をスローするか、通常の方法を使ってただちに終了させることになっています。
IOException
public final boolean isBlocking()
SelectableChannel
の記述:このチャネルがクローズしている場合、このメソッドの戻り値は特定されません。
SelectableChannel
内の isBlocking
public final Object blockingLock()
SelectableChannel
の記述:configureBlocking
メソッドと register
メソッドが同期するオブジェクトを返します。この機能は、特定のブロックモードを短時間保持する必要があるアダプタを実装する場合に便利です。
SelectableChannel
内の blockingLock
public final SelectableChannel configureBlocking(boolean block) throws IOException
指定されたブロックモードが現在のブロックモードと異なっている場合、このメソッドは、適切なロックを保持した状態で implConfigureBlocking
メソッドを呼び出してモードを変更します。
SelectableChannel
内の configureBlocking
block
- true の場合はこのチャネルがブロックモードになり、false の場合は非ブロックモードになる
ClosedChannelException
- このチャネルがクローズしている場合
IOException
- 入出力エラーが発生した場合protected abstract void implConfigureBlocking(boolean block) throws IOException
このメソッドは、ブロックモードを変更する実際の処理を行うために、configureBlocking
メソッドによって呼び出されます。このメソッドは、新しいモードが現在のモードと異なっている場合に限り呼び出されます。
IOException
- 入出力エラーが発生した場合
|
JavaTM Platform Standard Ed. 6 |
|||||||||
前のクラス 次のクラス | フレームあり フレームなし | |||||||||
概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド |
Copyright 2009 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Documentation Redistribution Policy も参照してください。