|
Java プラットフォーム 1.2 |
|||||||||
前のクラス 次のクラス | フレームあり フレームなし | |||||||||
概要: 内部クラス | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド |
java.lang.Object | +--java.io.InputStream | +--java.io.PipedInputStream
パイプで連結された入力ストリームは、パイプで連結された出力ストリームに接続されます。つまり、パイプで連結された入力ストリームは、パイプで連結された出力ストリームに書き込まれるデータバイトを提供します。一般に、PipedInputStream
オブジェクトからデータを読み込むスレッドと、対応する PipedOutputStream
オブジェクトにデータを書き込むスレッドは別々です。単一のスレッドからこれらの 2 つのオブジェクトを使うことは、そのスレッドをデッドロックさせる危険があるため、推奨できません。パイプで連結された入力ストリームは一定の範囲内でバッファを保持し、これにより書き込み処理と読み込み処理は分離されます。
PipedOutputStream
フィールドの概要 | |
protected byte[] |
buffer
入ってくるデータを置く循環バッファです。 |
protected int |
in
データの次のバイトをパイプで連結された接続済みの出力ストリームから受け取ったときに、その次のバイトを格納する循環バッファのインデックス位置です。 |
protected int |
out
パイプで連結されたこの入力ストリームがデータの次のバイトを読み込む、循環バッファのインデックス位置です。 |
protected static int |
PIPE_SIZE
パイプの循環入力バッファのサイズです。 |
コンストラクタの概要 | |
PipedInputStream()
PipedInputStream を、まだ接続されていない状態で作成します。 |
|
PipedInputStream(PipedOutputStream src)
PipedInputStream を、パイプで連結された出力ストリーム src に接続されるように作成します。 |
メソッドの概要 | |
int |
available()
ブロックせずにこの入力ストリームから読み込めるバイト数を返します。 |
void |
close()
パイプによる入力ストリームを閉じ、そのストリームに関連するすべてのシステムリソースを解放します。 |
void |
connect(PipedOutputStream src)
パイプによる入力ストリームを、パイプによる出力ストリーム src に接続させます。 |
int |
read()
パイプによる入力ストリームから、次のバイトを読み込みます。 |
int |
read(byte[] b,
int off,
int len)
パイプによる入力ストリームの len バイトまでのデータをバイトの配列に読み込みます。 |
protected void |
receive(int b)
データのバイトを受け取ります。 |
クラス java.io.InputStream から継承したメソッド |
mark,
markSupported,
read,
reset,
skip |
クラス java.lang.Object から継承したメソッド |
clone,
equals,
finalize,
getClass,
hashCode,
notify,
notifyAll,
toString,
wait,
wait,
wait |
フィールドの詳細 |
protected static final int PIPE_SIZE
protected byte[] buffer
protected int in
in<0
はバッファが空であることを示し、in==out
はバッファがいっぱいであることを示します。protected int out
コンストラクタの詳細 |
public PipedInputStream(PipedOutputStream src) throws IOException
PipedInputStream
を、パイプで連結された出力ストリーム src
に接続されるように作成します。src
に書き込まれるデータバイトは、このストリームからの入力として使用できます。src
- 接続するストリームpublic PipedInputStream()
PipedInputStream
を、まだ接続されていない状態で作成します。これを使うには、PipedOutputStream
に接続する必要があります。connect(java.io.PipedOutputStream)
,
PipedOutputStream.connect(java.io.PipedInputStream)
メソッドの詳細 |
public void connect(PipedOutputStream src) throws IOException
src
に接続させます。このオブジェクトがパイプによるほかの出力ストリームにすでに接続されている場合は、IOException
がスローされます。
src
がパイプによる未接続の出力ストリームで、snk
がパイプによる未接続の入力ストリームである場合、2 つのストリームは以下の呼び出しのどちらかによって接続されます。
snk.connect(src)
または、
src.connect(snk)
2 つの呼び出しの効果は同じです。
src
- パイプによる接続先の出力ストリームprotected void receive(int b) throws IOException
b
- 受け取るデータpublic int read() throws IOException
0
〜 255
までの範囲で int
として返されます。ストリームの終わりに達してバイトがない場合は、値 -1
が返されます。このメソッドは、入力データが読み込めるようになるか、ストリームの終わりが検出されるか、または例外がスローされるまでブロックします。スレッドがデータバイトを接続済みのパイプ出力ストリームに提供していたが、そのスレッドがもう生存していない場合は、IOException
がスローされます。-1
public int read(byte[] b, int off, int len) throws IOException
len
バイトまでのデータをバイトの配列に読み込みます。データストリームの終わりに達した場合は、len
バイトより少ないデータしか読み込まれません。このメソッドは、少なくとも 1 バイトが使用できるようになるまでブロックします。スレッドがデータバイトを接続済みのパイプ出力ストリームに提供していたが、そのスレッドがもう生存していない場合は、IOException
がスローされます。b
- データを読み込むバッファoff
- データの開始オフセットlen
- 読み込むバイトの最大数-1
public int available() throws IOException
available
メソッドをオーバーライドします。public void close() throws IOException
|
Java プラットフォーム 1.2 |
|||||||||
前のクラス 次のクラス | フレームあり フレームなし | |||||||||
概要: 内部クラス | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド |