Java NIO -- 管道 (Pipe)

Posted 西北野狼

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java NIO -- 管道 (Pipe)相关的知识,希望对你有一定的参考价值。

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

举个例子:

package com.soyoungboy.nio;

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

import org.junit.Test;

public class TestPipe {

    @Test
    public void test1() throws IOException{
        //1. 获取管道
        Pipe pipe = Pipe.open();
        
        //2. 将缓冲区中的数据写入管道
        ByteBuffer buf = ByteBuffer.allocate(1024);
        
        Pipe.SinkChannel sinkChannel = pipe.sink();
        buf.put("通过单向管道发送数据".getBytes());
        buf.flip();
        sinkChannel.write(buf);
        
        //3. 读取缓冲区中的数据
        Pipe.SourceChannel sourceChannel = pipe.source();
        buf.flip();
        int len = sourceChannel.read(buf);
        System.out.println(new String(buf.array(), 0, len));
        
        sourceChannel.close();
        sinkChannel.close();
    }
    
}

 

以上是关于Java NIO -- 管道 (Pipe)的主要内容,如果未能解决你的问题,请参考以下文章

Java NIO -- 管道 (Pipe)

Java NIO 管道 (Pipe)

Java NIO系列教程 Pipe

Java NIO管道

Java NIO系列教程 Pipe

转:Java NIO系列教程 Pipe