第五课 管道

  • Java NIO 管道(Pipe)是两个线程之间的单向数据连接。Pipe有一个 source 通道和一个 sink 通道。数据会被写到 sink 通道,从 source 通道读取。

第五课 管道


package NIO;

import java.io.IOException;
import java.nio.ByteBuffer;
import java.nio.channels.Pipe;

public class TestPipe {
	public static void main(String[] args) {
		Sink();
	}

	public static void Sink() {
		Pipe pipe = null;
		Pipe.SinkChannel sinkChannel = null;
		try {
			// 获取管道
			pipe = Pipe.open();
			// 获取Pipe内部类 SinkChannel
			sinkChannel = pipe.sink();
			// 创建缓冲区
			ByteBuffer buf = ByteBuffer.allocate(1024);
			// 将数据写入缓冲区
			buf.put("sink--发送".getBytes());
			// 转换缓冲区为读模式
			buf.flip();
			// 将缓冲区写入通道
			sinkChannel.write(buf);
			buf.clear();
			Pipe.SourceChannel sourceChannel = pipe.source();
			sourceChannel.read(buf);
			buf.flip();
			System.out.println(new String(buf.array(), 0, buf.limit()));
			buf.clear();
		} catch (IOException e) {
			e.printStackTrace();
		} finally {
			if (sinkChannel != null) {
				try {
					sinkChannel.close();
				} catch (IOException e) {
					e.printStackTrace();
				}
			}
		}
	}
}

上一篇:苹果Mac时间追踪工具推荐:Time Sink


下一篇:live555作为客户端接受H264视频流实现步骤