JavaTM Platform
Standard Ed. 6

java.io
クラス LineNumberInputStream

java.lang.Object
  上位を拡張 java.io.InputStream
      上位を拡張 java.io.FilterInputStream
          上位を拡張 java.io.LineNumberInputStream
すべての実装されたインタフェース:
Closeable

推奨されていません。 このクラスは、文字がバイトによって適切に表現されるという誤った認識を前提としています。JDK 1.1 以降、文字ストリームの処理には、行番号をカウントするためのクラスが含まれている新しい文字ストリームクラスを使用するのが適切です。

@Deprecated
public class LineNumberInputStream
extends FilterInputStream

このクラスは入力ストリームフィルタであり、現在の行番号を監視して保持する機能が追加されています。

行とはバイトの連なりであり、キャリッジリターン文字 ('\r')、改行文字 ('\n')、またはキャリッジリターン文字とそれに続く改行文字で終ります。これら 3 種類のすべてで、行を終了させる文字は 1 個の改行文字として返されます。

行番号は 0 から始まり、read が改行文字を返すたびに 1 ずつ増分します。

導入されたバージョン:
JDK1.0
関連項目:
LineNumberReader

フィールドの概要
 
クラス java.io.FilterInputStream から継承されたフィールド
in
 
コンストラクタの概要
LineNumberInputStream(InputStream in)
          推奨されていません。 指定された入力ストリームから読み込む、新しい行番号付き入力ストリームを作成します
 
メソッドの概要
 int available()
          推奨されていません。 ブロックせずに入力ストリームから読み込むことができるバイト数を返します。
 int getLineNumber()
          推奨されていません。 現在の行番号を返します。
 void mark(int readlimit)
          推奨されていません。 この入力ストリームの現在位置にマークを設定します。
 int read()
          推奨されていません。 この入力ストリームからデータの次のバイトを読み込みます。
 int read(byte[] b, int off, int len)
          推奨されていません。 最大 len バイトまでのデータを、この入力ストリームからバイト配列に読み込みます。
 void reset()
          推奨されていません。 このストリームの位置を、入力ストリームで最後に mark メソッドが呼び出されたときのマーク位置に再設定します。
 void setLineNumber(int lineNumber)
          推奨されていません。 行番号を指定された引数で設定します。
 long skip(long n)
          推奨されていません。 この入力ストリームから n バイト分をスキップおよび破棄します。
 
クラス java.io.FilterInputStream から継承されたメソッド
close, markSupported, read
 
クラス java.lang.Object から継承されたメソッド
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

コンストラクタの詳細

LineNumberInputStream

public LineNumberInputStream(InputStream in)
推奨されていません。 
指定された入力ストリームから読み込む、新しい行番号付き入力ストリームを作成します

パラメータ:
in - 基本となる入力ストリーム
メソッドの詳細

read

public int read()
         throws IOException
推奨されていません。 
この入力ストリームからデータの次のバイトを読み込みます。値のバイトは、0255 の範囲の int として返されます。ストリームの終わりに達したために読み込むバイトがない場合は、値 -1 が返されます。入力データが読み込めるようになるか、ファイルの終わりが検出されるか、または例外が発生するまで、このメソッドはブロックされます。

LineNumberInputStreamread メソッドが、基本となる入力ストリームの read メソッドを呼び出します。入力に現れるキャリッジリターン文字と改行文字を調べ、適切な行番号を保ちます。キャリッジリターン文字とキャリッジリターン+改行文字は、どちらも 1 個の改行文字に変換されます。

オーバーライド:
クラス FilterInputStream 内の read
戻り値:
データの次のバイト。ストリームの終わりに達した場合は -1
例外:
IOException - 入出力エラーが発生した場合
関連項目:
FilterInputStream.in, getLineNumber()

read

public int read(byte[] b,
                int off,
                int len)
         throws IOException
推奨されていません。 
最大 len バイトまでのデータを、この入力ストリームからバイト配列に読み込みます。このメソッドは、入力の一部が利用できるようになるまでブロックします。

LineNumberInputStreamread メソッドは引数を取らない read メソッドを繰り返し呼び出して配列に書き込みます。

オーバーライド:
クラス FilterInputStream 内の read
パラメータ:
b - データの読み込み先のバッファ
off - データの開始オフセット
len - 読み込まれる最大バイト数
戻り値:
バッファーに読み込まれたバイトの総数。ストリームの終わりに達して読み込むデータがなかった場合は -1
例外:
IOException - 入出力エラーが発生した場合
関連項目:
read()

skip

public long skip(long n)
          throws IOException
推奨されていません。 
この入力ストリームから n バイト分をスキップおよび破棄します。さまざまな理由から、skip メソッドは指定よりも少ないバイト数しかスキップしないことがあります。0 の場合もあります。スキップされた実際のバイト数が返されます。n が負の場合、バイトはスキップされません。

LineNumberInputStreamskip メソッドはバイト配列を作成し、n バイトが読み込まれるまで、またはストリームの終わりに達するまで繰り返しその中に読み込みます。

オーバーライド:
クラス FilterInputStream 内の skip
パラメータ:
n - スキップするバイト数
戻り値:
実際にスキップされたバイト数
例外:
IOException - 入出力エラーが発生した場合
関連項目:
FilterInputStream.in

setLineNumber

public void setLineNumber(int lineNumber)
推奨されていません。 
行番号を指定された引数で設定します。

パラメータ:
lineNumber - 新規行番号
関連項目:
getLineNumber()

getLineNumber

public int getLineNumber()
推奨されていません。 
現在の行番号を返します。

戻り値:
現在の行番号
関連項目:
setLineNumber(int)

available

public int available()
              throws IOException
推奨されていません。 
ブロックせずに入力ストリームから読み込むことができるバイト数を返します。

ブロックせずに基本となる入力ストリームから k 個の文字を読み込み可能な場合、LineNumberInputStream がブロックせずに読み込み可能な文字数は k/2 となる可能性があることに注意してください。これは、基本となる入力ストリームからの k 個の文字が k/2 対の '\r''\n' である可能性もあり、これが k/2 個の '\n' 文字に変換されるかもしれないからです。

オーバーライド:
クラス FilterInputStream 内の available
戻り値:
ブロックしないで入力ストリームから読み込むことができるバイト数
例外:
IOException - 入出力エラーが発生した場合
関連項目:
FilterInputStream.in

mark

public void mark(int readlimit)
推奨されていません。 
この入力ストリームの現在位置にマークを設定します。これに続いて reset メソッドを呼び出すと、最後にマークが設定された位置にストリームを再設定するため、次回の読み込み操作では同じバイトから読み込むことになります。

LineNumberInputStreammark メソッドは、private 変数に現在の行番号を記録してから、基本となる入力ストリームの mark メソッドを呼び出します。

オーバーライド:
クラス FilterInputStream 内の mark
パラメータ:
readlimit - マーク位置が無効になる前に読み込み可能なバイトの最大リミット
関連項目:
FilterInputStream.in, reset()

reset

public void reset()
           throws IOException
推奨されていません。 
このストリームの位置を、入力ストリームで最後に mark メソッドが呼び出されたときのマーク位置に再設定します。

LineNumberInputStreamreset メソッドは、まず行番号を mark メソッドが呼び出された時点の値にリセットし、それから基本となる入力ストリームの reset メソッドを呼び出します。

ストリームのマークは、ストリームに何が含まれているかをチェックするために、データを少しだけ先読みする必要がある場合に使われます。これをもっとも容易に実行する方法は、一般的なパーサーを呼び出すことです。ストリームがパーサーで取り扱えるタイプであれば、これでうまく行きます。ストリームがそのようなタイプではない場合、パーサーは失敗した時点で例外を発生させます。これにより、readlimit バイトの範囲内でこれが発生した場合は、外部のコードでストリームをリセットし、別のパーサーを呼び出すことができます。

オーバーライド:
クラス FilterInputStream 内の reset
例外:
IOException - 入出力エラーが発生した場合
関連項目:
FilterInputStream.in, mark(int)

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 も参照してください。