通过管道进行线程间通信:字节流。字符流的用法及API类似

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

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

package thread.communicate;

import java.io.IOException;
import java.io.PipedInputStream;
import java.io.PipedOutputStream;

/*2015-11-19*/
public class CommunicateWithPipedStream {
    public static void main(String[] args) {
        try {
            PipedOutputStream out = new PipedOutputStream();
            DataWriter writer = new DataWriter(out);
            PipedInputStream in = new PipedInputStream();
            DataReader reader = new DataReader(in);
            // out.connect(in);
            in.connect(out);
         new Thread(writer, "Writer").start();
            new Thread(reader, "Reader").start();
        } catch (Exception e) {
            e.printStackTrace();
        }

    }
}

class DataWriter implements Runnable {
    private PipedOutputStream _out;

    public DataWriter(PipedOutputStream out) {
        super();
        this._out = out;
    }

    @Override
    public void run() {
        write();
    }

    public void write() {
        System.out.println(Thread.currentThread() + "Start write....");
        try {
            for (int i = 0; i < 20; i++) {
                String outStr = "" + (i + 1);
                System.out.println(Thread.currentThread() + outStr);
                _out.write(outStr.getBytes());
            }
            _out.close();

        } catch (IOException e) {
            e.printStackTrace();
        }

    }

}

class DataReader implements Runnable {

    private PipedInputStream _in;

    public DataReader(PipedInputStream in) {
        _in = in;
    }

    @Override
    public void run() {
        read();
    }

    public void read() {
        try {
            System.out.println(Thread.currentThread() + "Start read....");
            byte[] byteArray = new byte[20];
            int readLength = _in.read(byteArray);
            while (readLength != -1) {
                String newData = new String(byteArray, 0, readLength);
                System.out.println(Thread.currentThread() + newData);
                readLength = _in.read(byteArray);
            }
            System.out.println();
            _in.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

}


输出:

Thread[Writer,5,main]Start write....
Thread[Writer,5,main]1
Thread[Reader,5,main]Start read....
Thread[Writer,5,main]2
Thread[Reader,5,main]1
Thread[Reader,5,main]2
Thread[Writer,5,main]3
Thread[Writer,5,main]4
Thread[Writer,5,main]5
Thread[Writer,5,main]6
Thread[Writer,5,main]7
Thread[Writer,5,main]8
Thread[Writer,5,main]9
Thread[Writer,5,main]10
Thread[Writer,5,main]11
Thread[Writer,5,main]12
Thread[Writer,5,main]13
Thread[Writer,5,main]14
Thread[Writer,5,main]15
Thread[Writer,5,main]16
Thread[Writer,5,main]17
Thread[Writer,5,main]18
Thread[Writer,5,main]19
Thread[Writer,5,main]20
Thread[Reader,5,main]34567891011121314151
Thread[Reader,5,main]617181920

 





相关文章
|
10天前
|
存储 Java 数据库连接
java多线程之线程通信
java多线程之线程通信
|
10天前
|
安全 编译器 C#
C#学习相关系列之多线程---lock线程锁的用法
C#学习相关系列之多线程---lock线程锁的用法
|
10天前
|
C#
C#学习相关系列之多线程---ConfigureAwait的用法
C#学习相关系列之多线程---ConfigureAwait的用法
|
10天前
|
C#
C#学习相关系列之多线程---TaskCompletionSource用法(八)
C#学习相关系列之多线程---TaskCompletionSource用法(八)
|
2天前
|
JSON API 数据格式
详细介绍下PYTHON API的用法
详细介绍下PYTHON API的用法
|
10天前
|
存储 缓存 安全
【C/C++ 关键字 存储类说明符 】 线程局部变量的魔法:C++ 中 thread_local的用法
【C/C++ 关键字 存储类说明符 】 线程局部变量的魔法:C++ 中 thread_local的用法
36 0
|
2天前
|
Java 调度
【JAVA学习之路 | 提高篇】线程的通信
【JAVA学习之路 | 提高篇】线程的通信
|
6天前
|
Java
Java一分钟之-并发编程:线程间通信(Phaser, CyclicBarrier, Semaphore)
【5月更文挑战第19天】Java并发编程中,Phaser、CyclicBarrier和Semaphore是三种强大的同步工具。Phaser用于阶段性任务协调,支持动态注册;CyclicBarrier允许线程同步执行,适合循环任务;Semaphore控制资源访问线程数,常用于限流和资源池管理。了解其使用场景、常见问题及避免策略,结合代码示例,能有效提升并发程序效率。注意异常处理和资源管理,以防止并发问题。
29 2
|
10天前
|
存储 NoSQL Redis
深入浅出Redis(二):Redis单线程模型与通信流程
深入浅出Redis(二):Redis单线程模型与通信流程
|
10天前
|
Java API 调度
【Java多线程】Thread类的基本用法
【Java多线程】Thread类的基本用法
13 0