【JAVA】【NIO】6、Java NIO Channel to Channel Transfers

來源:互聯網
上載者:User

標籤:java   nio   翻譯   channel   

在Java NIO中,如果其中有一個channel是FileChannel,你可以直接將資料從一個channel傳遞到另一個channel。FileChannel類有一個transferTo和一個transferFrom方法可以做到。

transferFrom()

該方法將資料從一個源channel傳遞到FileChannel。
執行個體:

參數position和count,表明在目標檔案中,從哪個位置開始寫,最大傳輸多少位元組(count)資料。如果源channel裡的資料少於count位元組,那麼傳輸的資料相應也會變少。

此外,一些SocketChannel的實現只傳輸那些此時此刻在SocketChannel的內部buffer的資料,即使SocketChannel稍後會有更多的資料。所以,它不會從SocketChannel傳輸整個請求資料(count)到FileChannel中。

transferTo()

該方法將資料從FileChannel傳輸到其它channel。
執行個體:

注意上面這個例子和前面的例子很像。僅僅不同的是FileChannel的調用方法,其它都一樣。

關於SocketChannel的問題對於transferTo也存在。SocketChannel的實現僅僅傳遞來自FileChannel的資料,知道發送的buffer滿了,才停止。

【JAVA】【NIO】6、Java NIO Channel to Channel Transfers

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.