内容简介:有没有更好的方法来处理这个或者我正在使用的实现与我将得到的一样好?如果一个输入流必须被多个消费者读取,并且输入流是短暂的(即,不是可以’重绕’或支持多个输入指针的资源),您通常必须提供一个缓冲方案,其行为就好像它会保留每个数据项,直到所有消费者都阅读它为止.您有多种实施选择.最简单的是你的建议,开销主要是输出缓冲区中多个数据副本的存储空间.如果存储是一个问题,您可以提供单个缓冲区来维护单独的读指针,每个消费者一个,并且仅在内存中保留最低和最高读指针之间的数据.如果消费者以非常不同的速度读取数据,您仍然可能最
有没有更好的方法来处理这个或者我正在使用的实现与我将得到的一样好?
如果一个输入流必须被多个消费者读取,并且输入流是短暂的(即,不是可以’重绕’或支持多个输入指针的资源),您通常必须提供一个缓冲方案,其行为就好像它会保留每个数据项,直到所有消费者都阅读它为止.
您有多种实施选择.最简单的是你的建议,开销主要是输出缓冲区中多个数据副本的存储空间.如果存储是一个问题,您可以提供单个缓冲区来维护单独的读指针,每个消费者一个,并且仅在内存中保留最低和最高读指针之间的数据.如果消费者以非常不同的速度读取数据,您仍然可能最终得到内存中的大部分或全部输入数据,此时某种输入限制或中间磁盘缓冲方案将变得必要.
我假设单个输入流不是持久的(即磁盘上的文件)……在这种情况下,解决方案是微不足道的.
翻译自:https://stackoverflow.com/questions/3135472/best-way-to-pipe-data-from-one-input-stream-to-multiple-output-streams
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
HTML5秘籍(第2版)
[美] Matthew MacDonald / 李松峰、朱巍、刘帅 / 人民邮电出版社 / 2015-4 / 89.00元
不依赖插件添加音频和视频,构建适用于所有浏览器的播放页面。 用Canvas创建吸引人的视觉效果,绘制图形、图像、文本,播放动画,运行交互游戏。 用CSS3将页面变活泼,比如添加新奇的字体,利用变换和动画添加吸引人的效果。 设计更出色的Web表单,利用HTML5新增的表单元素更加高效地收集访客信息。 一次开发,多平台运行,实现响应式设计,创建适配桌面计算机、平板电脑和智能手机......一起来看看 《HTML5秘籍(第2版)》 这本书的介绍吧!