Java NIO系列教程(十一) Pipe

发布时间:2016-12-10 1:28:13 编辑:www.fx114.net 分享查询网我要评论
本篇文章主要介绍了"Java NIO系列教程(十一) Pipe",主要涉及到Java NIO系列教程(十一) Pipe方面的内容,对于Java NIO系列教程(十一) Pipe感兴趣的同学可以参考一下。

Java NIO 管道是2个线程之间的单向数据连接。Pipe有一个source通道和一个sink通道。数据会被写到sink通道,从source通道读取。 这里是Pipe原理的图示: 创建管道 通过Pipe.open()方法打开管道。例如: 1 Pipe pipe = Pipe.open(); 向管道写数据 要向管道写数据,需要访问sink通道。像这样: 1 Pipe.SinkChannel sinkChannel = pipe.sink(); 通过调用SinkChannel的write()方法,将数据写入SinkChannel,像这样: 01 String newData = "New String to write to file..." + System.currentTimeMillis(); 02 ByteBuffer buf = ByteBuffer.allocate(48); 03 buf.clear(); 04 buf.put(newData.getBytes()); 05   06 buf.flip(); 07   08 while(buf.hasRemaining()) { 09     <b>sinkChannel.write(buf);</b> 10 } 从管道读取数据 从读取管道的数据,需要访问source通道,像这样: 1 Pipe.SourceChannel sourceChannel = pipe.source(); 调用source通道的read()方法来读取数据,像这样: 1 ByteBuffer buf = ByteBuffer.allocate(48); 2   3 int bytesRead = inChannel.read(buf); read()方法返回的int值会告诉我们多少字节被读进了缓冲区。

上一篇:mapreduce实例-Join连接 (reduce Side Join)
下一篇:OA系统项目需求

相关文章

相关评论