|
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 메소드를 지원하고 있지 않았기 때문에,falseInputStream.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 도 참조해 주세요.