JAVA NIO 翻譯系列(八、 SocketChannel)

Java NIO SocketChannel是一個連接tcp 協(xié)議的socket的channel。跟以前的java 網(wǎng)絡(luò)socket是一樣的,有兩個方式去創(chuàng)建。

1)連接一個服務(wù)端,打開一個SocketChannel

2)當(dāng)一個連接抵達(dá)ServerSocketChannel,SocketChannel可以被創(chuàng)建

打開SocketChannel

SocketChannel socketChannel = SocketChannel.open();

socketChannel.connect(new InetSocketAddress("http://jenkov.com", 80));

關(guān)閉SocketChannel

socketChannel.close();

?從SocketChannel讀

ByteBuffer buf = ByteBuffer.allocate(48);

int bytesRead = socketChannel.read(buf);

read方法讀取數(shù)據(jù)從channel到buffer,返回值表示多少個數(shù)據(jù)讀到buffer里面了,如果返回-1,代表流已經(jīng)讀取到頭了,或者連接關(guān)閉了。

向SocketChannel中寫

注意write方法是在一個循環(huán)內(nèi)部的.。因為無法保證有多少個數(shù)據(jù)寫到Channel中,所以不斷重復(fù)直到buffer中沒有要寫的數(shù)據(jù)了。

非阻塞模式

你可以 設(shè)置SocketChannel為非阻塞模式,設(shè)置之后,調(diào)用connect()、read()、write()方法在異步模式下。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Java NIO(New IO)是從Java 1.4版本開始引入的一個新的IO API,可以替代標(biāo)準(zhǔn)的Java I...
    JackChen1024閱讀 7,941評論 1 143
  • 前言: 之前的文章《Java文件IO常用歸納》主要寫了Java 標(biāo)準(zhǔn)IO要注意的細(xì)節(jié)和技巧,由于網(wǎng)上各種學(xué)習(xí)途徑,...
    androidjp閱讀 3,239評論 0 22
  • 簡介 Java NIO 是由 Java 1.4 引進(jìn)的異步 IO.Java NIO 由以下幾個核心部分組成: Ch...
    永順閱讀 1,856評論 0 15
  • (轉(zhuǎn)載說明:本文非原創(chuàng),轉(zhuǎn)載自http://ifeve.com/java-nio-all/) Java NIO: ...
    數(shù)獨題閱讀 866評論 0 3
  • java nio Java的IO體系:舊IO新IO:nio,用ByteBuffer和FileChannel讀寫ni...
    則不達(dá)閱讀 914評論 0 2

友情鏈接更多精彩內(nèi)容