java的nio中的管道,就类似于实际中的管道,有两端,一段作为输入,一段作为输出。也就是说,在创建了一个管道后,既可以对管道进行写,也可以对管道进行读,不过这两种操作要分别在两端进行。有点类似于队列的方式。
这里是pipe原理的图示:
创建管道
通过pipe.open()方法打开管道。例如:
pipe pipe = pipe.open();
向管道写数据
要向管道写数据,需要访问sink通道。像这样:
pipe.sinkchannel sinkchannel = pipe.sink();
通过调用sinkchannel的write()方法,将数据写入sinkchannel,像这样:
1
2
3
4
5
6
7
8
|
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); } |
我们在测试例子中给出一个非常简单的管道操作,先向管道写入内容,再从管道读出内容。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
package com.test.nio; import java.io.ioexception; import java.nio.bytebuffer; import java.nio.channels.pipe; public class testpipea { /** * @param args * @throws exception */ public static void main(string[] args) throws exception { //创建一个管道 pipe pipe=pipe.open(); //创建一个写管道 pipe.sinkchannel sinkchannel=pipe.sink(); string newdata= "itbuluoge.com says:" +system.currenttimemillis(); bytebuffer buf=bytebuffer.allocate( 48 ); buf.clear(); buf.put(newdata.getbytes()); buf.flip(); /*向管道写入内容*/ while(buf.hasremaining()) { sinkchannel.write(buf); } /*创建一个读管道*/ pipe.sourcechannel sourcechannel=pipe.source(); bytebuffer getbuf=bytebuffer.allocate(48); int bytesread=sourcechannel.read(getbuf); getbuf.flip(); /*从管道读出内容*/ while (getbuf.hasremaining()) { system.out.print(( char )getbuf.get()); } } } |
输出结果
我们可以看到,已经可以完成我们需要的目标了。注意,我在这个地方编程的时候,出现了一点错误,就是我在读取管道的时候,没有设置getbuf.flip(),导致无法读出数据,这个函数非常重要,在完成buffer读取内容之后,一定要设置一下读标志,恢复指针到原始位置,才能读取到全部内容。
以上就是本文关于java的nio管道用法代码分享的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
原文链接:http://blog.csdn.net/itbuluoge/article/details/39552769