NIO详解(十一):线程间通信管道Pipe
生活随笔
收集整理的這篇文章主要介紹了
NIO详解(十一):线程间通信管道Pipe
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1. 概述
Java NIO 管道是2個線程之間的單向數據連接。Pipe有一個source通道和一個sink通道。數據會被寫到sink通道,從source通道讀取。下面是Pipe原理的圖示:
當有兩個線程ThreadA和ThreadB需要進行線程間通信時,ThreadA可以通過SinkChannel向Pipe中寫入數據。ThreadB可以通過SourceChannel從Pipe中讀取數據。
2. 創建管道
通過Pipe.open()方法打開管道。例如:
Pipe pipe = Pipe.open();3. 向管道寫數據
要向管道寫數據,需要訪問sink通道。像這樣:
Pipe.SinkChannel sinkChannel = pipe.sink();通過調用SinkChannel的write()方法,將數據寫入SinkChannel,像這樣:
String newData = "New String to write to file..." + System.currentTimeMillis(); ByteBuffer buf = ByteBuffer.allocate(48); buf.clear(); buf.put(newData.getBytes());buf.flip();while(buf.hasRemaining()) {sinkChannel.write(buf); }4. 從管道讀取數據
從讀取管道的數據,需要訪問source通道,像這樣:
Pipe.SourceChannel sourceChannel = pipe.source();調用source通道的read()方法來讀取數據,像這樣:
ByteBuffer buf = ByteBuffer.allocate(48); int bytesRead = sourceChannel.read(buf);read()方法返回的int值會告訴我們多少字節被讀進了緩沖區。
總結
以上是生活随笔為你收集整理的NIO详解(十一):线程间通信管道Pipe的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: NIO详解(九):Selector详解
- 下一篇: NIO详解(十二):Asynchrono