提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
前言
java多线程场景,线程与线程之间需要通信协作,管道就是其中之一;
例如场景:按照用户搜索条件查询数据,并将数据下载到用户本地,那系统通常的做法就是按照用户检索条件查询出结果集,将结果集生成excel表,在将excel表上传到ftp或者oss云盘之类的地方,最后将下载连接发送给用户,最后用户点击链接进行下载,那么使用管道就减少了数据生成到本地,在上传到云盘的工作,直接生成到用户下载,提高用户体验和效率。
一、管道-使用方式
- PipedOutputStream
- PipedInputStream
- PipedWriter
- PipedReader
前两种基础字节流,后两种基础字符流
二、PipedWriter、PipedReader实现多线程从控制台读取用户输入输出
public class PipedTeset {
public static void main(String[] args) throws IOException {
PipedReader in = new PipedReader();
PipedWriter out = new PipedWriter();
out.connect(in);
Thread printThread = new Thread(new PrintThread(in), "printThread");
printThread.start();
int receive = 0;
try {
while ((receive = System.in.read()) != -1) {
// 主线程进行读取控制台输入
out.write(receive);
}
} catch (RuntimeException e) {
}
}
static class PrintThread implements Runnable{
private PipedReader in;
public PrintThread(PipedReader in) {
this.in = in;
}
@Override
public void run() {
int receive;
try {
while ((receive = in.read()) != -1){
// printThread 收到字符然后输入,这里可以使用sokcet编程将字符传输到对应计算机中
System.out.print((char) receive);
}
} catch (IOException e) {
throw new RuntimeException(e);
}
}
}
}