有什么方法可以使用java.nio。*在不關(guān)閉套接字的情況下中斷InputStream#read()?
如果在讀取過程中中斷了InterruptibleChannel,它將被關(guān)閉并拋出ClosedByInterruptException。如果您只想讀取超時(shí),請不要使用任何通道,而只需使用常規(guī)的Socket;用較短的超時(shí)調(diào)用Socket.setSoTimeout(),并在每次超時(shí)觸發(fā)時(shí)檢查線程的isInterrupted()狀態(tài)。更好的是,查看中斷線程的要求。那個(gè)有什么用途?
解決方法您是否知道在InputStream不關(guān)閉關(guān)聯(lián)套接字的情況下中斷Java讀取的方法?
這是獲取套接字輸入流并轉(zhuǎn)換為可中斷的DataInputStream的當(dāng)前構(gòu)造策略:
InputStream interruptibleInputStream = Channels.newInputStream(Channels.newChannel(m_ConnectionData.getSocket().getInputStream()));DataInputStream myInterruptibleDIS = new DataInputStream(interruptibleInputStream);
這利用ReadableByteChannel提供了read(ByteBuffer)對ClosedByInterruptExceptionthrowable的支持的方法的a。
問題在于,在線程上調(diào)用中斷再在原因read()上調(diào)用DataInputStream會導(dǎo)致底層套接字被關(guān)閉。
就我而言,我需要使套接字保持打開狀態(tài)。該read呼叫正在等待即將到來的用戶輸入,因此我正在使用中斷將控制權(quán)傳遞回更高的組件,然后最終read再次返回。
如果有人可以提出一種使用JDK內(nèi)置類實(shí)現(xiàn)此目標(biāo)的方法,或者指出某些信息是不可能的,我將不勝感激。
我知道還有其他方法可以達(dá)到相同的效果,但是我很想知道這種方法是否可行。
相關(guān)文章:
1. mysql - sql 左連接結(jié)果union右連接結(jié)果,導(dǎo)致重復(fù)性計(jì)算怎么解決?2. 怎么能做出標(biāo)簽切換頁的效果,(文字內(nèi)容隨動)3. mysql 遠(yuǎn)程連接出錯(cuò)10060,我已經(jīng)設(shè)置了任意主機(jī)了。。。4. 默認(rèn)輸出類型為json,如何輸出html5. 數(shù)組排序,并把排序后的值存入到新數(shù)組中6. php多任務(wù)倒計(jì)時(shí)求助7. mysql的主從復(fù)制、讀寫分離,關(guān)于從的問題8. mysql怎么表示兩個(gè)字段的差9. PHP訂單派單系統(tǒng)10. MySQL的聯(lián)合查詢[union]有什么實(shí)際的用處
