|
JavaTM Platform Standard Ed. 6 |
|||||||||
앞의 클래스 다음의 클래스 | 프레임 있어 프레임 없음 | |||||||||
개요: 상자 | 필드 | 생성자 | 메소드 | 상세 : 필드 | 생성자 | 메소드 |
java.lang.Objectjava.io.InputStream
java.io.FilterInputStream
java.io.PushbackInputStream
public class PushbackInputStream
PushbackInputStream
는, 다른 입력 스트림에 기능을 추가합니다. 구체적으로는, 1 바이트를 「push back(되밀치는)」또는 「안리드」하는 기능을 추가합니다. 이것은, 특정의 바이트치로 단락지어진 부정수의 데이터 바이트를 코드 fragment로 읽어들이면(자) 형편상 좋은 상황으로 도움이 됩니다. 끝 바이트를 읽어들이면(자), 코드 fragment는 그것을 「안리드」할 수 있으므로, 입력 스트림의 다음의 read 조작에서는, push back(되밀치는) 된 그 바이트를 재차 읽어들이게 됩니다. 예를 들어, 식별자를 구성해 있는 문자를 나타내는 일련의 바이트는, 연산자 문자를 나타내는 바이트로 끝나는 일이 있습니다. 이 경우, 식별자를 1 개만 읽어들이는 작업을 가지는 메소드는, 연산자를 검출할 때까지 read를 실행해, 재차 read를 실시하기 위해서(때문에) 연산자를 push back(되밀치는) 할 수가 있습니다.
필드의 개요 | |
---|---|
protected byte[] |
buf
push back(되밀치는) 버퍼입니다. |
protected int |
pos
push back(되밀치는) 버퍼내의 다음의 바이트의 read 위치입니다. |
클래스 java.io. FilterInputStream 로부터 상속된 필드 |
---|
in |
생성자 의 개요 | |
---|---|
PushbackInputStream (InputStream in)
PushbackInputStream 를 작성해, 그 인수인 입력 스트림 in 를 나중에 사용할 수 있도록(듯이) 보존합니다. |
|
PushbackInputStream (InputStream in,
int size)
지정된 size 의 부시 백 버퍼를 가지는 PushbackInputStream 를 작성해, 그 인수인 입력 스트림 in 를 나중에 사용할 수 있도록(듯이) 보존합니다. |
메소드의 개요 | |
---|---|
int |
available ()
이 입력 스트림의 메소드의 다음의 호출에 의해, 블록 하지 않고 이 입력 스트림로부터 읽어들일 수가 있는 (또는 스킵 할 수 있다) 추정 바이트수를 돌려줍니다. |
void |
close ()
이 입력 스트림을 닫아, 그 스트림에 관련하는 모든 system resource를 해제합니다. |
void |
mark (int readlimit)
이 입력 스트림의 현재 위치에 마크를 설정합니다. |
boolean |
markSupported ()
이 입력 스트림이, mark 메소드와 reset 메소드를 지원하고 있을지 어떨지를 판정합니다. |
int |
read ()
이 입력 스트림로부터 데이터의 다음의 바이트를 읽어들입니다. |
int |
read (byte[] b,
int off,
int len)
최대 len 바이트까지의 데이터를, 이 입력 스트림로부터 바이트 배열에 읽어들입니다. |
void |
reset ()
이 스트림의 위치를, 입력 스트림로 마지막에 mark 메소드가 불려 갔을 때의 마크 위치에 재설정합니다. |
long |
skip (long n)
이 입력 스트림로부터 n 바이트분을 스킵 및 파기합니다. |
void |
unread (byte[] b)
push back(되밀치는) 버퍼의 선두에 바이트 배열을 카피하는 것에 의해, 바이트 배열을 push back(되밀치는) 합니다. |
void |
unread (byte[] b,
int off,
int len)
push back(되밀치는) 버퍼의 선두에 바이트 배열의 일부를 카피하는 것에 의해, 그러한 바이트를 push back(되밀치는) 합니다. |
void |
unread (int b)
push back(되밀치는) 버퍼의 선두에 1 바이트를 카피하는 것에 의해, 그 바이트를 push back(되밀치는) 합니다. |
클래스 java.io. FilterInputStream 로부터 상속된 메소드 |
---|
read |
클래스 java.lang. Object 로부터 상속된 메소드 |
---|
clone , equals , finalize , getClass , hashCode , notify , notifyAll , toString , wait , wait , wait |
필드의 상세 |
---|
protected byte[] buf
protected int pos
pos
는 buf.length
에 일치해, 버퍼가 가득한 경우,pos
는 제로에 일치합니다.
생성자 의 상세 |
---|
public PushbackInputStream(InputStream in, int size)
size
의 부시 백 버퍼를 가지는 PushbackInputStream
를 작성해, 그 인수인 입력 스트림 in
를 나중에 사용할 수 있도록(듯이) 보존합니다. 초기 상태에서는, push back(되밀치는) 된 바이트는 없습니다. pushBack
필드는 -1
에 초기화되고 있습니다.
in
- 바이트의 read원의 입력 스트림size
- push back(되밀치는) 버퍼의 사이즈
IllegalArgumentException
- 사이즈가 0 이하의 경우public PushbackInputStream(InputStream in)
PushbackInputStream
를 작성해, 그 인수인 입력 스트림 in
를 나중에 사용할 수 있도록(듯이) 보존합니다. 초기 상태에서는, push back(되밀치는) 된 바이트는 없습니다. pushBack
필드는 -1
에 초기화되고 있습니다.
in
- 바이트의 read원의 입력 스트림메소드의 상세 |
---|
public int read() throws IOException
0
~ 255
의 범위의 int
로서 돌려주어집니다. 스트림의 마지막에 이르렀기 때문에 읽어들이는 바이트가 없는 경우는, 값 -1
이 돌려주어집니다. 입력 데이터를 읽어들일 수 있게 되는지, 파일의 마지막이 검출되는지, 또는 예외가 발생할 때까지, 이 메소드는 블록 됩니다.
이 메소드는, 마지막에 push back(되밀치는) 된 바이트가 있는 경우에는 그것을 돌려줍니다. 그것이 없는 경우, 그 기본이 되는 입력 스트림의 read
메소드를 호출해 그 반환값을 돌려줍니다.
FilterInputStream
내의 read
-1
IOException
- 이 입력 스트림이 close()
메소드의 호출에 의해 닫혀졌을 경우, 또는 입출력 에러가 발생했을 경우InputStream.read()
public int read(byte[] b, int off, int len) throws IOException
len
바이트까지의 데이터를, 이 입력 스트림로부터 바이트 배열에 읽어들입니다. 이 메소드는, push back(되밀치는) 된 바이트가 있으면 그것들을 최초로 읽어들입니다. 다음에, 읽힌 바이트가 len
바이트보다 적은 경우는, 기본이 되는 입력 스트림로부터 읽어들입니다. len
가 0 이 아닌 경우, 이 메소드는 입력의 적어도 1 바이트를 이용할 수 있게 될 때까지 블록 합니다. 그렇지 않은 경우, 바이트는 읽히지 않고,0
이 돌려주어집니다.
FilterInputStream
내의 read
b
- 데이터의 read처의 버퍼off
- 전송처의 배열 b
내에서의 개시 오프셋(offset)len
- 읽히는 최대 바이트수
-1
NullPointerException
- b
가 null
의 경우
IndexOutOfBoundsException
- off
가 부의 경우,len
가 부의 경우, 또는 len
가 b.length - off
보다 큰 경우
IOException
- 이 입력 스트림이 close()
메소드의 호출에 의해 닫혀졌을 경우, 또는 입출력 에러가 발생했을 경우InputStream.read(byte[], int, int)
public void unread(int b) throws IOException
(byte) b
를 가집니다.
b
- push back(되밀치는) 되는 하위의 바이트를 가지는 int
치
IOException
- 바이트에 대해서, push back(되밀치는) 버퍼에 충분한 스페이스가 없는 경우, 또는 이 입력 스트림이 close()
메소드의 호출에 의해 닫혀졌을 경우public void unread(byte[] b, int off, int len) throws IOException
b[off]
를 가져, 그 다음의 바이트는 값 b[off+1]
를 가집니다. 그 이후도 이와 같이 계속됩니다.
b
- push back(되밀치는) 하는 바이트의 배열off
- 데이터의 개시 오프셋(offset)len
- push back(되밀치는) 하는 바이트수
IOException
- 지정된 바이트수에 대해서, push back(되밀치는) 버퍼에 충분한 스페이스가 없는 경우, 또는 이 입력 스트림이 close()
메소드의 호출에 의해 닫혀졌을 경우public void unread(byte[] b) throws IOException
b[0]
을 가져, 그 다음의 바이트는 값 b[1]
을 가집니다. 그 이후도 이와 같이 계속됩니다.
b
- push back(되밀치는) 하는 바이트의 배열
IOException
- 지정된 바이트수에 대해서, push back(되밀치는) 버퍼에 충분한 스페이스가 없는 경우, 또는 이 입력 스트림이 close()
메소드의 호출에 의해 닫혀졌을 경우public int available() throws IOException
이 메소드는, push back(되밀치는) 된 바이트수의 합계와 available
에 의해 반환된 값을 돌려줍니다.
FilterInputStream
내의 available
IOException
- 이 입력 스트림이 close()
메소드의 호출에 의해 닫혀졌을 경우, 또는 입출력 에러가 발생했을 경우FilterInputStream.in
,
InputStream.available()
public long skip(long n) throws IOException
n
바이트분을 스킵 및 파기합니다. 다양한 이유로부터,skip
메소드는 지정보다 적은 바이트수 밖에 스킵 하지 않는 것이 있습니다. 0 의 경우도 있습니다. n
가 부의 경우, 바이트는 스킵 되지 않습니다.
PushbackInputStream
의 skip
메소드는, 부시 백 버퍼에 바이트가 존재하면, 최초로 그것들을 스킵 합니다. 한층 더 스킵 할 필요가 있는 바이트가 존재하면(자), 기본이 되는 입력 스트림의 skip
메소드를 호출합니다. 스킵 된 실제의 바이트수가 돌려주어집니다.
FilterInputStream
내의 skip
n
- 스킵 하는 바이트수
IOException
- 스트림이 시크를 지원하고 있지 않는 경우, 스트림이 close()
메소드의 호출에 의해 닫혀졌을 경우, 또는 입출력 에러가 발생했을 경우FilterInputStream.in
,
InputStream.skip(long n)
public boolean markSupported()
mark
메소드와 reset
메소드를 지원하고 있을지 어떨지를 판정합니다. 이러한 메소드는 지원되고 있지 않습니다.
FilterInputStream
내의 markSupported
mark
메소드와 reset
메소드를 지원하고 있지 않았기 때문에,false
InputStream.mark(int)
,
InputStream.reset()
public void mark(int readlimit)
PushbackInputStream
의 mark
메소드는 아무것도 실시하지 않습니다.
FilterInputStream
내의 mark
readlimit
- 마크 위치가 무효가 되기 전에 읽어들여 가능한 최대한도의 바이트수InputStream.reset()
public void reset() throws IOException
mark
메소드가 불려 갔을 때의 마크 위치에 재설정합니다.
PushbackInputStream
클래스의 reset
메소드는,IOException
를 throw 하는 이외 아무것도 실시하지 않습니다.
FilterInputStream
내의 reset
IOException
- 이 메소드가 불려 갔을 경우InputStream.mark(int)
,
IOException
public void close() throws IOException
Closeable
내의 close
FilterInputStream
내의 close
IOException
- 입출력 에러가 발생했을 경우FilterInputStream.in
|
JavaTM Platform Standard Ed. 6 |
|||||||||
앞의 클래스 다음의 클래스 | 프레임 있어 프레임 없음 | |||||||||
개요: 상자 | 필드 | 생성자 | 메소드 | 상세 : 필드 | 생성자 | 메소드 |
Copyright 2006 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms . Documentation Redistribution Policy 도 참조해 주세요.