zoukankan      html  css  js  c++  java
  • 如何理解流Stream

    百度百科:

    计算机中的流其实是一种信息的转换。它是一种有序流,因此相对于某一对象,通常我们把对象接收外界的信息输入(Input)称为输入流,相应地从对象向外输出(Output)信息为输出流,合称为输入/输出流(I/O Streams)。对象间进行信息或者数据的交换时总是先将对象或数据转换为某种形式的流,再通过流的传输,到达目的对象后再将流转换为对象数据。所以,可以把流看作是一种数据的载体,通过它可以实现数据交换和传输。

    数据流的概念

    数据流(data stream)最初是通信领域使用的概念,代表传输中所使用的信息的数字编码信号序列。然而,我们所提到的数据流概念与此不同。这个概念最初在1998年由Henzinger在文献87中提出,他将数据流定义为“只能以事先规定好的顺序被读取一次的数据的一个序列”。

    可以再读一读该词条详细内容,介绍了流的性质。

    IO流

    流是一种抽象概念,它代表了数据的无结构化传递。按照流的方式进行输入输出,数据被当成无结构的字节序或字符序列。从流中取得数据的操作称为提取操作,而向流中添加数据的操作称为插入操作。用来进行输入输出操作的流就称为IO流。换句话说,IO流就是以流的方式进行输入输出 [1]  。

    在IO流里,输入输出分为4步:格式化/解析,缓冲,编码转换和传递。
    格式化/解析:在内部数据表示(以字节为单位)与外部数据表示(以字符为单位)之间进行双向转换。例如一个2字节的整数10002,就需要5个字符来表示。
    缓冲:用于在格式/解析与传递只加缓存字符序列。对于输出,较短的字符序列格式化之后并不马上输出,而是保存在缓冲区里,待累积到一定规模之后再传递到外部设备。相反,从外部设备读入的大量数据也是先放在缓冲区,然后逐步取出完成输入。默认时,IO流的输入输出都是经过缓冲的,也可以让IO流工作在无缓冲模式下。
    编码转换: 是将一种字符表达式转换成另一种字符表达式。如果格式化产生的字符表达式与外部字符表达式不同(输出时),或者外部表达式与IO流能解析的表达式不同(输入时),就必须进行编码转换。如多字节编码与宽字符编码之间的转换等。多数情况下并不需要进行编码转换。
    传递:主要是与外部设备进行通信。输出时,传递负责将经过格式化、缓冲即编码转换后的字符序列发送到外部设备;输入时,则负责将外部设备抽取数据,为其后进行的编码转换、缓冲及解析提供字符序列。
     
    需要再读一读这个概念。
     
    https://stackoverflow.com/questions/507747/can-you-explain-the-concept-of-streams
    stackoverflow上的解释

    选择“流”这个词是因为它代表(在现实生活中)与我们在使用它时要传达的内容非常相似的含义。

    让我们暂时忘记后备商店,并开始考虑与水流的类比。您可以获得连续的数据流,就像水不断流入河流一样。您不一定知道数据的来源,通常您不需要;无论是从文件,套接字还是任何其他来源,它都不(不应该)真正重要。这与接收水流非常相似,因此您无需知道它来自何处;无论是从湖泊,喷泉还是其他任何来源,它都不(不应该)真的很重要。

    也就是说,一旦你开始认为你只关心获取所需的数据,无论它来自哪里,其他人谈论的抽象变得更加清晰。你开始认为你可以包装流,你的方法仍然可以完美地工作。

     

    另一种解释:

    关键是你不应该知道后备存储是什么 - 它是对它的抽象。 实际上,甚至可能没有后备存储 - 您可能正在从网络中读取数据,并且数据永远不会“存储”。

    如果您可以编写的代码无论您是在与文件系统,内存,网络还是其他任何支持流概念的内容进行通信,那么您的代码就会更加灵活。

    此外,流通常链接在一起 - 你可以有一个流压缩放入其中的任何内容,将压缩的表单写入另一个流,或者加密数据的流,等等。另一端是反向的 链,解密,解压缩等等。

     
  • 相关阅读:
    主库binlog(master-log)与从库relay-log的关系
    binlog_format不同模式下,对mysqlbinlog恢复的影响
    主从 binlog_format 设置关系
    Mysql5.7多源复制,过滤复制一段时间后增加复制一个库的实现方法
    mysql 5.7安装过程中,初始化的问题
    mysql复制过滤参数说明
    模块化发展
    Angular指令内容小结
    vue项目打包到腾讯云服务器全过程
    Centos7安装Mysql5.7
  • 原文地址:https://www.cnblogs.com/Tpf386/p/9648487.html
Copyright © 2011-2022 走看看