|
JavaTM Platform Standard Ed. 6 |
|||||||||
앞의 클래스 다음의 클래스 | 프레임 있어 프레임 없음 | |||||||||
개요: 상자 | 필드 | 생성자 | 메소드 | 상세 : 필드 | 생성자 | 메소드 |
java.lang.Objectjava.io.InputStream
java.io.FilterInputStream
public class FilterInputStream
FilterInputStream
는, 데이터의 기본적인 소스로서 사용하기 위한 그 외의 입력 스트림을 포함합니다. 데이터를 도중에 변환하는 것이나, 추가 기능을 제공하는 일도 있습니다. FilterInputStream
클래스 그 자체가, 포함되고 있는 입력 스트림에 모든 요구를 건네주는 버젼에 의해,InputStream
의 모든 메소드를 단순하게 오버라이드(override) 합니다. FilterInputStream
의 서브 클래스는, 이러한 메소드의 일부를 한층 더 오버라이드(override) 할 수가 있어 추가의 메소드나 필드를 제공할 수도 있습니다.
필드의 개요 | |
---|---|
protected InputStream |
in
필터 처리되는 입력 스트림입니다. |
생성자 의 개요 | |
---|---|
protected |
FilterInputStream (InputStream in)
나중에 사용할 수 있도록(듯이) 인수 in 를 this.in 필드에 할당하는 것에 의해,FilterInputStream 를 작성합니다. |
메소드의 개요 | |
---|---|
int |
available ()
이 입력 스트림의 메소드의 다음의 호출 측에야는, 블록 하지 않고 이 입력 스트림로부터 읽어들일 수가 있는 (또는 스킵 할 수 있다) 추정 바이트수를 돌려줍니다. |
void |
close ()
이 입력 스트림을 닫아, 그 스트림에 관련하는 모든 system resource를 해제합니다. |
void |
mark (int readlimit)
이 입력 스트림의 현재 위치에 마크를 설정합니다. |
boolean |
markSupported ()
입력 스트림이 mark 와 reset 메소드를 지원하고 있을지 어떨지를 판정합니다. |
int |
read ()
이 입력 스트림로부터 데이터의 다음의 바이트를 읽어들입니다. |
int |
read (byte[] b)
최대 byte.length 바이트까지의 데이터를, 이 입력 스트림로부터 바이트 배열에 읽어들입니다. |
int |
read (byte[] b,
int off,
int len)
최대 len 바이트까지의 데이터를, 이 입력 스트림로부터 바이트 배열에 읽어들입니다. |
void |
reset ()
이 스트림의 위치를, 입력 스트림로 마지막에 mark 메소드가 불려 갔을 때의 마크 위치에 재설정합니다. |
long |
skip (long n)
이 입력 스트림로부터 n 바이트분을 스킵 및 파기합니다. |
클래스 java.lang. Object 로부터 상속된 메소드 |
---|
clone , equals , finalize , getClass , hashCode , notify , notifyAll , toString , wait , wait , wait |
필드의 상세 |
---|
protected volatile InputStream in
생성자 의 상세 |
---|
protected FilterInputStream(InputStream in)
in
를 this.in
필드에 할당하는 것에 의해,FilterInputStream
를 작성합니다.
in
- 기본이 되는 입력 스트림. 기본이 되는 스트림없이 이 인스턴스가 작성 되려고 하고 있는 경우는 null
메소드의 상세 |
---|
public int read() throws IOException
0
~ 255
의 범위의 int
로서 돌려주어집니다. 스트림의 마지막에 이르렀기 때문에 읽어들이는 바이트가 없는 경우는, 값 -1
이 돌려주어집니다. 입력 데이터를 읽어들일 수 있게 되는지, 파일의 마지막이 검출되는지, 또는 예외가 발생할 때까지, 이 메소드는 블록 됩니다.
이 메소드는 단순하게 in.read()
를 실행해, 그 결과를 돌려줍니다.
InputStream
내의 read
-1
IOException
- 입출력 에러가 발생했을 경우in
public int read(byte[] b) throws IOException
byte.length
바이트까지의 데이터를, 이 입력 스트림로부터 바이트 배열에 읽어들입니다. 이 메소드는, 입력의 일부를 이용할 수 있게 될 때까지 블록 합니다.
이 메소드는 단순하게 read(b, 0, b.length)
의 호출을 실행해, 그 결과를 돌려줍니다. 대신에 in.read(b)
가 실행되지 않게 해 주세요. FilterInputStream
의 특정의 서브 클래스는, 실제로 사용되고 있는 구현 방법으로 의존합니다.
InputStream
내의 read
b
- 데이터의 read처의 버퍼
-1
IOException
- 입출력 에러가 발생했을 경우read(byte[], int, int)
public int read(byte[] b, int off, int len) throws IOException
len
바이트까지의 데이터를, 이 입력 스트림로부터 바이트 배열에 읽어들입니다. len
가 0 이 아닌 경우, 이 메소드는 입력의 일부를 이용할 수 있게 될 때까지 블록 합니다. 그렇지 않은 경우, 바이트는 읽히지 않고,0
이 돌려주어집니다.
이 메소드는 단순하게 in.read(b, off, len)
를 실행해, 그 결과를 돌려줍니다.
InputStream
내의 read
b
- 데이터의 read처의 버퍼off
- 전송처의 배열 b
내에서의 개시 오프셋(offset)len
- 읽히는 최대 바이트수
-1
NullPointerException
- b
가 null
의 경우
IndexOutOfBoundsException
- off
가 부의 경우,len
가 부의 경우, 또는 len
가 b.length - off
보다 큰 경우
IOException
- 입출력 에러가 발생했을 경우in
public long skip(long n) throws IOException
n
바이트분을 스킵 및 파기합니다. 다양한 이유로부터,skip
메소드는 지정보다 적은 바이트수 밖에 스킵 하지 않는 것이 있습니다. 0
의 경우도 있습니다. 이 스킵은 복수의 조건에 기인할 가능성이 있습니다만, 생각되는 유일한 경우는,n
바이트가 스킵 되기 전에 파일의 마지막에 이르렀을 경우입니다. 스킵 된 실제의 바이트수가 돌려주어집니다. n
가 부의 경우, 바이트는 스킵 되지 않습니다.
이 클래스의 skip
메소드는 바이트 배열을 작성해,n
바이트가 읽힐 때까지, 또는 스트림의 마지막에 이를 때까지 반복 그 중에 읽어들입니다. 서브 클래스에서 이 메소드를 구현하는 경우는, 보다 효율적으로 구현해 주세요. 예를 들어, 구현은 시크의 기능에 의존할 가능성이 있습니다.
이 메소드는 단순하게 in.skip(n)
를 실행합니다.
InputStream
내의 skip
n
- 스킵 하는 바이트수
IOException
- 스트림이 시크를 지원하지 않는 경우, 또는 그 외의 입출력 에러가 발생했을 경우public int available() throws IOException
이 메소드가 돌려주는 것은 in
. available()의 결과입니다.
InputStream
내의 available
IOException
- 입출력 에러가 발생했을 경우public void close() throws IOException
in.close()
를 실행합니다.
Closeable
내의 close
InputStream
내의 close
IOException
- 입출력 에러가 발생했을 경우in
public void mark(int readlimit)
reset
메소드를 호출하면(자), 마지막에 마크가 설정된 위치에 스트림을 재설정하기 위해(때문에), 다음번의 read 조작에서는 같은 바이트로부터 읽어들이게 됩니다.
인수 readlimit
는 이 입력 스트림에 대해서, 마크 위치가 무효가 되기 전에 이 인수가 지정하는 바이트수를 읽어들이도록(듯이) 지시합니다.
이 메소드는 단순하게 in.mark(readlimit)
를 실행합니다.
InputStream
내의 mark
readlimit
- 마크 위치가 무효가 되기 전에 읽어들여 가능한 최대한도의 바이트수in
,
reset()
public void reset() throws IOException
mark
메소드가 불려 갔을 때의 마크 위치에 재설정합니다.
이 메소드는 단순하게 in.reset()
를 실행합니다.
스트림의 마크는, 스트림에 무엇이 포함되어 있는지를 체크하기 위해서, 데이터를 약간 예측할 필요가 있는 경우에 사용됩니다. 이것을 가장 용이하게 실행하는 방법은, 일반적인 퍼서를 호출하는 것입니다. 스트림을 퍼서로 취급할 수 있는 타입이면, 이것으로 잘 되어갑니다. 스트림이 이러한 타입이 아닌 경우는, 퍼서는 실패한 시점에서 예외를 발생시킵니다. readlimit 바이트의 범위내에서 이것이 발생했을 경우는, 외부의 코드로 스트림을 리셋 해, 다른 퍼서를 호출할 수가 있습니다.
InputStream
내의 reset
IOException
- 스트림에 마크가 설정되어 있지 않았던 경우, 또는 마크가 무효가 되어 있었을 경우in
,
mark(int)
public boolean markSupported()
mark
와 reset
메소드를 지원하고 있을지 어떨지를 판정합니다. 이 메소드는 단순하게 in.markSupported()
를 실행합니다.
- 오버라이드(override):
- 클래스
InputStream
내의 markSupported
- 반환값:
- 이 스트림 타입이
mark
및 reset
메소드를 지원하는 경우는 true
, 그렇지 않은 경우는 false
- 관련 항목:
in
,
InputStream.mark(int)
,
InputStream.reset()
|
JavaTM Platform Standard Ed. 6 |
|||||||||
앞의 클래스 다음의 클래스 | 프레임 있어 프레임 없음 | |||||||||
개요: 상자 | 필드 | 생성자 | 메소드 | 상세 : 필드 | 생성자 | 메소드 |
Copyright 2006 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms . Documentation Redistribution Policy 도 참조해 주세요.