管道流|学习笔记

简介: 快速学习 管道流

开发者学堂课程【Java 高级编程管道流】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/20/detail/324


管道流


内容简介:

1. 管道流介绍

2. 管道流的分类

3. 范例:实现管道操作

 

管道流介绍

实现两个线程之间的 IO 处理操作

图片15.png


管道流的分类

对于管道流也是分为两类:

· 字节管道流:PipedOutputStream、PipedInputStream;

连接处理:public void connect(PipedInputStream snk)throws IOException;

· 字符管道流:PipedWriter、PipedReader。

连接处理:public void connect(PipedReader snk)throws IOException

 

范例:实现管道操作

package cn.mldn.demo;

import java.io.ByteArrayOutputStream;

import java.io.IOException;

import java.io.PipedInputStream;

import java. io. Pipedoutputstream;

public class JavaAPIDemo {

public static void main(String[] args) throws Exception{SendThreadsend = new SendThread();

ReceiveThread receive = new ReceiveThread();

send.getoutput().connect(receive.getInput());//进行管道连接

new Thread(send,"消息发送线程").start();

new Thread(receive,"消息接收线程").start();

}

class SendThread implements Runnable {

privatePipedoutputstream output;//管道的输出流

public SendThread(){

this.output=new Pipedoutputstream();//实例化管道输出流

}

public void run(){

for (int x = 0; x < 10; x++) {try{//利用管道实现数据的发送处理

this.output.write(

(“【第”+(x+1)+“次信息发送-”+Thr

 

www.mldn.cn\n").getBytes());

}catch (IOException e) {

e.printstackTrace();

}

}

try {

this.output.close();

}catch (IOException e) {

e.printstackTrace();

}

}

public PipedOutputStream getOutput(){}

return output;

}

}

class ReceiveThread implements Runnable

{private PipedInputStream input;

public ReceiveThread(){

this.input = new PipedInputStream();

}

this.output.close();

}catch (IOException e) {

e.printstackTrace();

}

}

public PipedOutputStream getOutput(){

return output;

}

class ReceiveThread implements Runnable {

privatePipedInputStream input;

public ReceiveThread(){

this.input = new PipedInputStream();

}

@Override.

public void run(){

byte data[]=new byte[1024];

int len = 0;

ByteArrayOutputStream bos = new ByteArrayOutputStream()

try{

while ( (len = this. input. read (data)! =- 1) {

bos.write(data,e,len);//所有的数据保存到内存流System.out.println("{"+Thread.currentThread().getN String(bos.toByteArray()));

bos.close();

}catch (IOException e) {

e.printstackTrace();

}

}

public PipedInputstream getInput(){

return input;

}

管道就类似于医院打点滴效果,一个只是负责发送,一个负责接收,中间靠一个管道连接。

相关文章
|
11月前
|
存储 缓存 Java
Java中的分布式缓存与Memcached集成实战
通过在Java项目中集成Memcached,可以显著提升系统的性能和响应速度。合理的缓存策略、分布式架构设计和异常处理机制是实现高效缓存的关键。希望本文提供的实战示例和优化建议能够帮助开发者更好地应用Memcached,实现高性能的分布式缓存解决方案。
209 9
|
4天前
|
云安全 人工智能 自然语言处理
|
8天前
|
人工智能 Java API
Java 正式进入 Agentic AI 时代:Spring AI Alibaba 1.1 发布背后的技术演进
Spring AI Alibaba 1.1 正式发布,提供极简方式构建企业级AI智能体。基于ReactAgent核心,支持多智能体协作、上下文工程与生产级管控,助力开发者快速打造可靠、可扩展的智能应用。
798 17
|
11天前
|
数据采集 人工智能 自然语言处理
Meta SAM3开源:让图像分割,听懂你的话
Meta发布并开源SAM 3,首个支持文本或视觉提示的统一图像视频分割模型,可精准分割“红色条纹伞”等开放词汇概念,覆盖400万独特概念,性能达人类水平75%–80%,推动视觉分割新突破。
802 59
Meta SAM3开源:让图像分割,听懂你的话
|
2天前
|
人工智能 安全 小程序
阿里云无影云电脑是什么?最新收费价格个人版、企业版和商业版无影云电脑收费价格
阿里云无影云电脑是运行在云端的虚拟电脑,分企业版和个人版。企业版适用于办公、设计等场景,4核8G配置低至199元/年;个人版适合游戏、娱乐,黄金款14元/月起。支持多端接入,灵活按需使用。
235 164
|
9天前
|
搜索推荐 编译器 Linux
一个可用于企业开发及通用跨平台的Makefile文件
一款适用于企业级开发的通用跨平台Makefile,支持C/C++混合编译、多目标输出(可执行文件、静态/动态库)、Release/Debug版本管理。配置简洁,仅需修改带`MF_CONFIGURE_`前缀的变量,支持脚本化配置与子Makefile管理,具备完善日志、错误提示和跨平台兼容性,附详细文档与示例,便于学习与集成。
334 116

热门文章

最新文章