美文网首页
Java 通过管道进行线程间通信

Java 通过管道进行线程间通信

作者: 杰哥长得帅 | 来源:发表于2018-03-16 20:04 被阅读32次

Java 中的管道流(pipeStream)可以在不同线程间直接传送数据。一个线程发送数据到输出管道,另一个线程从输入管道中读数据。通过使用管道,实现不同线程间的通信,无须借助于类似临时文件的东西

在 Java 的 JDK 中提供了 4 个类来使线程间可以进行通信:

  1. PipedInputStream和PipedOutputStream
  2. PipedReader和PipedWriter

通过管道进行线程间通信:字节流/字符流

public class WriteData {
    public void writeMethod(PipedOutputStream out) {   // 字符流这里换成 PipeWriter
        try {
            System.out.println("write :");
            for (int i=0; i<10; i++) {
                String outData = "" + (i+1);
                out.write(outData.getBytes());    // 字符流这里换成 out.write(outData)
                System.out.print(outData);
            }
            System.out.println();
            out.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

public class ReadData {
    public void readMethod(PipedInputStream input) {    // 字符流这里换成 PipedReader
        try {
            System.out.println("read: ");
            byte[] byteArray = new byte[20];    // 字符流这里换成 char
            int readLength = input.read(byteArray);  
            while (readLength != -1) {
                String newData = new String(byteArray, 0, readLength);
                System.out.println(newData);
                readLength = input.read(byteArray);
            }
            System.out.println();
            input.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

两个自定义线程

public class ThreadWrite extends Thread {
    private WriteData write;
    private PipedOutputStream out;    // 字符流这里换成 PipedWriter

    public ThreadWrite(WriteData write, PipedOutputStream out) {    // 字符流这里换成 PipedWriter
        this.write = write;
        this.out = out;
    }
    public void run() {
        write.writeMethod(out);
    }
}

public class ThreadRead extends Thread {
    private ReadData read;
    private PipedInputStream input;    // 字符流这里换成 PipedRead

    public ThreadRead(ReadData read, PipedInputStream input) {   // 字符流这里换成 PipedRead
        this.read = read;
        this.input = input;
    }
    public void run() {
        read.readMethod(input);
    }
}

主类:

public class Run {
    public static void main(String[] args) throws InterruptedException, IOException {
        WriteData writeData = new WriteData();
        ReadData readData = new ReadData();

        PipedInputStream inputStream = new PipedInputStream();   // 字符流用 PipedReader
        PipedOutputStream outputStream = new PipedOutputStream();  // 字符流用 PipedWriter

        // 使两个 Stream 之间产生通信链接
        inputStream.connect(outputStream);   // 这两个只能用一个
        //outputStream.connect(inputStream);

        ThreadRead threadRead = new ThreadRead(readData,inputStream);
        threadRead.start();

        Thread.sleep(2000);

        ThreadWrite threadWrite = new ThreadWrite(writeData,outputStream);
        threadWrite.start();
    }
}

结果:

read:
write :
12345678910
12345678910

相关文章

  • Java 通过管道进行线程间通信

    Java 中的管道流(pipeStream)可以在不同线程间直接传送数据。一个线程发送数据到输出管道,另一个线程从...

  • PHP进程间通信--消息队列

    前面介绍了怎么通过消息管道(有名消息管道)进行进程间通信,下面介绍如何通过消息队列实现进程间通信。 首先我们来看一...

  • 浏览器运行原理

    进程 申请和拥有计算机资源 不同进程间通信通过进程间通信管道IPC 线程 一个进程多个线程,每个线程执行不同的任务...

  • Linux-C-day-2-进程通过--管道通信

    管道通信 进程间管道通信方式可以通过man 7 pipe来查看; 匿名管道 单工管道 打开管道:使用popen()...

  • java并发

    java并发的两个核心问题: 1:线程间如何通信2:线程间如何同步 1:通行通过共享变量,Java内存模型2:同步...

  • linux xargs,-exec,|管道的区别

    管道 | 管道是一种通信机制,通常用于进程间的通信(也可通过socket进行网络通信),它表现出来的形式将前面每一...

  • ios 多线程的故事4

    线程间通信 线程间通信:在1个进程中,线程往往不是孤立存在的,多个线程之间需要经常进行通信 线程间通信的体现 1个...

  • 线程间通信剖析——Java进阶

    Java线程间通信剖析 本文将介绍常用的线程间通信工具CountDownLatch、CyclicBarrier和P...

  • 【深入浅出Linux】Linux管道命令踩坑实录

    前言 看这个问题前我们要先明白什么是管道。 管道是一种通信机制,通常用于进程间的通信(也可通过socket进行网络...

  • JAVA IO

    Java IO: Pipes 管道支持线程间通讯,但不是线程安全的。 Java IO: Byte & Char A...

网友评论

      本文标题:Java 通过管道进行线程间通信

      本文链接:https://www.haomeiwen.com/subject/zyvrqftx.html