更新時間:2020-08-03 11:32:12 來源:動力節(jié)點(diǎn) 瀏覽3242次
1、IO里面的常見類,字節(jié)流、字符流、接口、實(shí)現(xiàn)類、方法阻塞?
輸入流就是從外部文件輸入到內(nèi)存,輸出流主要是從內(nèi)存輸出到文件。
IO里面常見的類,第一印象就只知道IO流中有很多類,IO流主要分為字符流和字節(jié)流。字符流中有抽象類InputStream和OutputStream,它們的子類FileInputStream,F(xiàn)ileOutputStream,BufferedOutputStream等。字符流BufferedReader和Writer等。都實(shí)現(xiàn)了Closeable,Flushable,Appendable這些接口。程序中的輸入輸出都是以流的形式保存的,流中保存的實(shí)際上全都是字節(jié)文件。
java中的阻塞式方法是指在程序調(diào)用改方法時,必須等待輸入數(shù)據(jù)可用或者檢測到輸入結(jié)束或者拋出異常,否則程序會一直停留在該語句上,不會執(zhí)行下面的語句。比如read()和readLine()方法。
2、談?wù)剬IO的認(rèn)知?
對于NIO,它是非阻塞式,核心類:
1.Buffer為所有的原始類型提供(Buffer)緩存支持。
2.Charset字符集編碼解碼解決方案
3.Channel一個新的原始I/O抽象,用于讀寫B(tài)uffer類型,通道可以認(rèn)為是一種連接,可以是到特定設(shè)備,程序或者是網(wǎng)絡(luò)的連接。
3、字節(jié)流和字符流的區(qū)別?
字符流和字節(jié)流的使用非常相似,但是實(shí)際上字節(jié)流的操作不會經(jīng)過緩沖區(qū)(內(nèi)存)而是直接操作文本本身的,而字符流的操作會先經(jīng)過緩沖區(qū)(內(nèi)存)然后通過緩沖區(qū)再操作文件
以字節(jié)為單位輸入輸出數(shù)據(jù),字節(jié)流按照8位傳輸
以字符為單位輸入輸出數(shù)據(jù),字符流按照16位傳輸
4、NIO和傳統(tǒng)的IO有什么區(qū)別?
1、傳統(tǒng)IO一般是一個線程等待連接,連接過來之后分配給processor線程,processor線程與通道連接后如果通道沒有數(shù)據(jù)過來就會阻塞(線程被動掛起)不能做別的事情。NIO則不同,首先,在selector線程輪詢的過程中就已經(jīng)過濾掉了不感興趣的事件,其次,在processor處理感興趣事件的read和write都是非阻塞操作即直接返回的,線程沒有被掛起。
2、傳統(tǒng)io的管道是單向的,nio的管道是雙向的。
3、兩者都是同步的,也就是java程序親力親為的去讀寫數(shù)據(jù),不管傳統(tǒng)io還是nio都需要read和write方法,這些都是java程序調(diào)用的而不是系統(tǒng)幫我們調(diào)用的,nio2.0里這點(diǎn)得到了改觀,即使用異步非阻塞AsynchronousXXX四個類來處理。
5、BIO和NIO和AIO的區(qū)別以及應(yīng)用場景?
同步:java自己去處理io。
異步:java將io交給操作系統(tǒng)去處理,告訴緩存區(qū)大小,處理完成回調(diào)。
阻塞:使用阻塞IO時,Java調(diào)用會一直阻塞到讀寫完成才返回。
非阻塞:使用非阻塞IO時,如果不能立馬讀寫,Java調(diào)用會馬上返回,當(dāng)IO事件分發(fā)器通知可讀寫時在進(jìn)行讀寫,不斷循環(huán)直到讀寫完成。
BIO:同步并阻塞,服務(wù)器的實(shí)現(xiàn)模式是一個連接一個線程,這樣的模式很明顯的一個缺陷是:由于客戶端連接數(shù)與服務(wù)器線程數(shù)成正比關(guān)系,可能造成不必要的線程開銷,嚴(yán)重的還將導(dǎo)致服務(wù)器內(nèi)存溢出。當(dāng)然,這種情況可以通過線程池機(jī)制改善,但并不能從本質(zhì)上消除這個弊端。
NIO:在JDK1.4以前,Java的IO模型一直是BIO,但從JDK1.4開始,JDK引入的新的IO模型NIO,它是同步非阻塞的。而服務(wù)器的實(shí)現(xiàn)模式是多個請求一個線程,即請求會注冊到多路復(fù)用器Selector上,多路復(fù)用器輪詢到連接有IO請求時才啟動一個線程處理。
AIO:JDK1.7發(fā)布了NIO2.0,這就是真正意義上的異步非阻塞,服務(wù)器的實(shí)現(xiàn)模式為多個有效請求一個線程,客戶端的IO請求都是由OS先完成再通知服務(wù)器應(yīng)用去啟動線程處理(回調(diào))。
應(yīng)用場景:并發(fā)連接數(shù)不多時采用BIO,因?yàn)樗幊毯驼{(diào)試都非常簡單,但如果涉及到高并發(fā)的情況,應(yīng)選擇NIO或AIO,更好的建議是采用成熟的網(wǎng)絡(luò)通信框架Netty。
以上就是動力節(jié)點(diǎn)java培訓(xùn)機(jī)構(gòu)的小編針對“精選Java io流練習(xí)題,大家趕快收藏吧”的內(nèi)容進(jìn)行的回答,希望對大家有所幫助,如有疑問,請?jiān)诰€咨詢,有專業(yè)老師隨時為你服務(wù)。
初級 202925
初級 203221
初級 202629
初級 203743