W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
java.lang.Object
|---java.io.InputStream
public abstract class InputStream
extends Object
implements Closeable
這個(gè)抽象類是代表字節(jié)輸入流的所有類的超類。
需要定義 InputStream 子類的應(yīng)用程序必須始終提供返回下一個(gè)輸入字節(jié)的方法。
Since:
JDK1.0
構(gòu)造函數(shù) | 描述 |
---|---|
InputStream() |
修飾符和類型 | 方法 | 描述 |
---|---|---|
int | available() | 返回可以從此輸入流中讀取(或跳過(guò))的字節(jié)數(shù)的估計(jì)值,而不會(huì)被下一次調(diào)用此輸入流的方法阻塞。 |
void | close() | 關(guān)閉此輸入流并釋放與該流關(guān)聯(lián)的所有系統(tǒng)資源。 |
void | mark(int readlimit) | 標(biāo)記此輸入流中的當(dāng)前位置。 |
boolean | markSupported() | 測(cè)試此輸入流是否支持 mark 和 reset 方法。 |
abstract int | read() | 從輸入流中讀取數(shù)據(jù)的下一個(gè)字節(jié)。 |
int | read(byte[] b) | 從輸入流中讀取一些字節(jié)并將它們存儲(chǔ)到緩沖區(qū)數(shù)組 b. |
int | read(byte[] b, int off, int len) | 從輸入流中讀取最多 len 個(gè)字節(jié)的數(shù)據(jù)到一個(gè)字節(jié)數(shù)組中。 |
void | reset() | 將此流重新定位到最后一次在此輸入流上調(diào)用標(biāo)記方法時(shí)的位置。 |
long | skip(long n) | 跳過(guò)并丟棄此輸入流中的 n 字節(jié)數(shù)據(jù)。 |
從類 java.lang.Object 繼承的方法 |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
public InputStream()
public abstract int read() throws IOException
從輸入流中讀取數(shù)據(jù)的下一個(gè)字節(jié)。 值字節(jié)作為 int 返回,范圍為 0 到 255。如果由于到達(dá)流的末尾而沒(méi)有可用的字節(jié),則返回值 -1。 此方法會(huì)一直阻塞,直到輸入數(shù)據(jù)可用、檢測(cè)到流結(jié)束或引發(fā)異常。
子類必須提供此方法的實(shí)現(xiàn)。
返回:
數(shù)據(jù)的下一個(gè)字節(jié),如果到達(dá)流的末尾,則為 -1。
Throws:
Throw名稱 | Throw描述 |
---|---|
IOException | 如果發(fā)生 I/O 錯(cuò)誤。 |
public int read(byte[] b) throws IOException
從輸入流中讀取一些字節(jié)并將它們存儲(chǔ)到緩沖區(qū)數(shù)組 b. 實(shí)際讀取的字節(jié)數(shù)以整數(shù)形式返回。 在輸入數(shù)據(jù)可用、檢測(cè)到文件結(jié)尾或引發(fā)異常之前,此方法會(huì)一直阻塞。
如果 b 的長(zhǎng)度為零,則不讀取任何字節(jié)并返回 0; 否則,將嘗試讀取至少一個(gè)字節(jié)。 如果由于流位于文件末尾而沒(méi)有可用字節(jié),則返回值 -1; 否則,至少讀取一個(gè)字節(jié)并將其存儲(chǔ)到 b 中。
讀取的第一個(gè)字節(jié)存儲(chǔ)在元素 b[0] 中,下一個(gè)字節(jié)存儲(chǔ)在 b[1] 中,依此類推。 讀取的字節(jié)數(shù)最多等于 b 的長(zhǎng)度。 設(shè) k 為實(shí)際讀取的字節(jié)數(shù); 這些字節(jié)將存儲(chǔ)在元素 b[0] 到 b[k-1] 中,而元素 b[k] 到 b[b.length-1] 不受影響。
InputStream 類的 read(b) 方法與以下效果相同:
read(b, 0, b.length)
參數(shù):
參數(shù)名稱 | 參數(shù)描述 |
---|---|
b | 讀取數(shù)據(jù)的緩沖區(qū)。 |
返回:
讀入緩沖區(qū)的總字節(jié)數(shù),如果由于到達(dá)流的末尾而沒(méi)有更多數(shù)據(jù),則為 -1。
Throws:
Throw名稱 | Throw描述 |
---|---|
IOException | 如果由于文件結(jié)尾以外的任何原因無(wú)法讀取第一個(gè)字節(jié),如果輸入流已關(guān)閉,或者發(fā)生其他一些 I/O 錯(cuò)誤。 |
NullPointerException | 如果 b 為空。 |
public int read(byte[] b, int off, int len) throws IOException
從輸入流中讀取最多 len 個(gè)字節(jié)的數(shù)據(jù)到一個(gè)字節(jié)數(shù)組中。嘗試讀取多達(dá) len 個(gè)字節(jié),但可能會(huì)讀取較小的字節(jié)數(shù)。實(shí)際讀取的字節(jié)數(shù)以整數(shù)形式返回。
在輸入數(shù)據(jù)可用、檢測(cè)到文件結(jié)尾或引發(fā)異常之前,此方法會(huì)一直阻塞。
如果 len 為零,則不讀取任何字節(jié)并返回 0;否則,將嘗試讀取至少一個(gè)字節(jié)。如果由于流位于文件末尾而沒(méi)有可用字節(jié),則返回值 -1;否則,至少讀取一個(gè)字節(jié)并將其存儲(chǔ)到 b 中。
讀取的第一個(gè)字節(jié)存儲(chǔ)在元素 b[off] 中,下一個(gè)字節(jié)存儲(chǔ)在 b[off+1] 中,依此類推。讀取的字節(jié)數(shù)最多等于 len。設(shè) k 為實(shí)際讀取的字節(jié)數(shù);這些字節(jié)將存儲(chǔ)在元素 b[off] 到 b[off+k-1] 中,而元素 b[off+k] 到 b[off+len-1] 不受影響。
在每種情況下,元素 b[0] 到 b[off] 和元素 b[off+len] 到 b[b.length-1] 都不受影響。
InputStream 類的 read(b, off, len) 方法只是重復(fù)調(diào)用方法 read()。如果第一個(gè)此類調(diào)用導(dǎo)致 IOException,則該異常會(huì)從對(duì) read(b, off, len) 方法的調(diào)用中返回。如果對(duì) read() 的任何后續(xù)調(diào)用導(dǎo)致 IOException,則捕獲該異常并將其視為文件結(jié)尾;到目前為止讀取的字節(jié)存儲(chǔ)在 b 中,并返回發(fā)生異常之前讀取的字節(jié)數(shù)。此方法的默認(rèn)實(shí)現(xiàn)會(huì)阻塞,直到讀取了請(qǐng)求的輸入數(shù)據(jù)量 len、檢測(cè)到文件結(jié)尾或拋出異常。鼓勵(lì)子類提供此方法的更有效實(shí)現(xiàn)。
參數(shù):
參數(shù)名稱 | 參數(shù)描述 |
---|---|
b | 讀取數(shù)據(jù)的緩沖區(qū)。 |
off | 數(shù)組 b 中寫(xiě)入數(shù)據(jù)的起始偏移量。 |
len | 要讀取的最大字節(jié)數(shù)。 |
返回:
讀入緩沖區(qū)的總字節(jié)數(shù),如果由于到達(dá)流的末尾而沒(méi)有更多數(shù)據(jù),則為 -1。
Throws:
Throw名稱 | Throw描述 |
---|---|
IOException | 如果由于文件結(jié)尾以外的任何原因無(wú)法讀取第一個(gè)字節(jié),或者輸入流已關(guān)閉,或者發(fā)生其他一些 I/O 錯(cuò)誤。 |
NullPointerException | 如果 b 為空。 |
IndexOutOfBoundsException | 如果 off 為負(fù)數(shù),len 為負(fù)數(shù),或者 len 大于 b.length - off |
public long skip(long n) throws IOException
跳過(guò)并丟棄此輸入流中的 n 字節(jié)數(shù)據(jù)。 由于各種原因,skip 方法最終可能會(huì)跳過(guò)一些較小的字節(jié)數(shù),可能是 0。這可能是由許多條件中的任何一個(gè)引起的; 在跳過(guò) n 個(gè)字節(jié)之前到達(dá)文件末尾只是一種可能性。 返回實(shí)際跳過(guò)的字節(jié)數(shù)。 如果 n 為負(fù)數(shù),則 InputStream 類的 skip 方法始終返回 0,并且不跳過(guò)任何字節(jié)。 子類可能以不同方式處理負(fù)值。
此類的 skip 方法創(chuàng)建一個(gè)字節(jié)數(shù)組,然后重復(fù)讀取它,直到讀取 n 個(gè)字節(jié)或到達(dá)流的末尾。 鼓勵(lì)子類提供此方法的更有效實(shí)現(xiàn)。 例如,實(shí)現(xiàn)可能取決于尋找的能力。
參數(shù):
參數(shù)名稱 | 參數(shù)描述 |
---|---|
n | 要跳過(guò)的字節(jié)數(shù)。 |
返回:
跳過(guò)的實(shí)際字節(jié)數(shù)。
Throws:
Throw名稱 | Throw描述 |
---|---|
IOException | 如果流不支持查找,或者發(fā)生其他一些 I/O 錯(cuò)誤。 |
public int available() throws IOException
返回可以從此輸入流中讀?。ɑ蛱^(guò))的字節(jié)數(shù)的估計(jì)值,而不會(huì)被下一次調(diào)用此輸入流的方法阻塞。下一次調(diào)用可能是同一個(gè)線程或另一個(gè)線程。單次讀取或跳過(guò)這么多字節(jié)不會(huì)阻塞,但可能會(huì)讀取或跳過(guò)更少的字節(jié)。
請(qǐng)注意,雖然 InputStream 的某些實(shí)現(xiàn)會(huì)返回流中的字節(jié)總數(shù),但許多不會(huì)。使用此方法的返回值來(lái)分配旨在保存此流中所有數(shù)據(jù)的緩沖區(qū)是不正確的。
如果此輸入流已通過(guò)調(diào)用 close() 方法關(guān)閉,則此方法的子類的實(shí)現(xiàn)可以選擇拋出 IOException。
InputStream 類的可用方法總是返回 0。
這個(gè)方法應(yīng)該被子類覆蓋。
返回:
可以在沒(méi)有阻塞的情況下從此輸入流中讀?。ɑ蛱^(guò))的字節(jié)數(shù)的估計(jì)值,或者當(dāng)它到達(dá)輸入流的末尾時(shí)為 0。
Throws:
Throw名稱 | Throw描述 |
---|---|
IOException | 如果發(fā)生 I/O 錯(cuò)誤。 |
public void close() throws IOException
關(guān)閉此輸入流并釋放與該流關(guān)聯(lián)的所有系統(tǒng)資源。
InputStream 的 close 方法什么也不做。
指定者:
在接口 AutoCloseable 中關(guān)閉
指定者:
在接口Closeable中關(guān)閉
Throws:
Throw名稱 | Throw描述 |
---|---|
IOException | 如果發(fā)生 I/O 錯(cuò)誤。 |
public void mark(int readlimit)
標(biāo)記此輸入流中的當(dāng)前位置。 對(duì) reset 方法的后續(xù)調(diào)用將此流重新定位到最后標(biāo)記的位置,以便后續(xù)讀取重新讀取相同的字節(jié)。
readlimit 參數(shù)告訴此輸入流允許在標(biāo)記位置無(wú)效之前讀取那么多字節(jié)。
mark 的一般約定是,如果方法 markSupported 返回 true,則流以某種方式記住調(diào)用 mark 之后讀取的所有字節(jié),并準(zhǔn)備好在調(diào)用方法 reset 時(shí)再次提供這些相同的字節(jié)。 但是,如果在調(diào)用 reset 之前從流中讀取了超過(guò) readlimit 個(gè)字節(jié),則流根本不需要記住任何數(shù)據(jù)。
標(biāo)記關(guān)閉的流不應(yīng)對(duì)流產(chǎn)生任何影響。
InputStream 的mark 方法什么都不做。
參數(shù):
參數(shù)名稱 | 參數(shù)描述 |
---|---|
readlimit | 在標(biāo)記位置無(wú)效之前可以讀取的最大字節(jié)數(shù)。 |
public void reset() throws IOException
將此流重新定位到最后一次在此輸入流上調(diào)用標(biāo)記方法時(shí)的位置。
重置的一般合約是:
InputStream 類的方法 reset 除了拋出一個(gè) IOException 之外什么都不做。
Throws:
Throw名稱 | Throw描述 |
---|---|
IOException | 如果此流尚未標(biāo)記或標(biāo)記已失效。 |
public boolean markSupported()
測(cè)試此輸入流是否支持 mark 和 reset 方法。 是否支持標(biāo)記和重置是特定輸入流實(shí)例的不變屬性。 InputStream 的 markSupported 方法返回 false。
返回:
如果此流實(shí)例支持 mark 和 reset 方法,則為 true; 否則為 false。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: