浅谈数据流

作者: lotus儿 | 来源:发表于2017-10-31 10:45 被阅读31次

姓名:周君会      学号:17011210526

转载自:

http://www.jianshu.com/p/b1326fe0dd94

【嵌牛导读】:信息的传输离不开数据流。

【嵌牛鼻子】:当今时代,大数据,云计算如火如荼,然而他们的背后都离不开数据流。

【嵌牛提问】:但是数据流是怎么传送的呢,数据流的传送机制是什么?

【嵌牛正文】:

什么是数据流

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

数据流是指一组有顺序的、有起点和终点的字节集合,程序从键盘接收数据或向文件中写数据,以及在网络连接上进行数据的读写操作,都可以使用数据流来完成。

数据流分类

数据的性质、格式不同,则对流的处理方法也不同,因此,在Java的输入/输出类库中,有不同的流类来对应不同性质的输入/输出流。在java.io包中,基本输入/输出流类可按其读写数据的类型之不同分为两种:字节流和字符流。

输入流与输出流

数据流分为输入流(InputStream)和输出流(OutputStream)两类。输入流只能读不能写,而输出流只能写不能读。通常程序中使用输入流读出数据,输出流写入数据,就好像数据流入到程序并从程序中流出。采用数据流使程序的输入输出操作独立与相关设备。

输入流可从键盘或文件中获得数据,输出流可向显示器、打印机或文件中传输数据。

缓冲流

为了提高数据的传输效率,通常使用缓冲流(Buffered Stream),即为一个流配有一个缓冲区(buffer),一个缓冲区就是专门用于传输数据的内存块。当向一个缓冲流写入数据时,系统不直接发送到外部设备,而是将数据发送到缓冲区。缓冲区自动记录数据,当缓冲区满时,系统将数据全部发送到相应的设备。

当从一个缓冲流中读取数据时,系统实际是从缓冲区中读取数据。当缓冲区空时,系统就会从相关设备自动读取数据,并读取尽可能多的数据充满缓冲区。

数据流的基本操作

1.生成数据流的基本过程

数据流由一系列的节点组成,当数据通过每个节点时,节点对它进行定义好的操作。建立数据流通常遵循以下4个步骤:

(1)向数据流区域增添新的节点;

(2)将这些节点连接到数据流中;

(3)设定数据节点或数据流的功能:

(4)运行数据流。

2.向数据流区域添加,删除节点

当向数据流区域添加新的节点时,通过下面3种方法均可实现:

(1)双击选项板区中待添加的节点。

(2)单击待添加节点,按住鼠标不放,将其拖入数据流区域内。

(3)先选中选项板区中待添加的节点,然后将鼠标放入数据流区域,在鼠标变为十字形时单击数据流区域的任何空白处。

通过上面3种方法都将发现选中的节点出现在了数据流区域内。当不再需要数据流区域内的某个节点时,可以通过以下两种方法来删除:

(1)单击待删除的节点,按Delete键删除。

(2)右击待删除的节点,在快捷菜单中选择delete命令。

注意,删除一个节点后,与之相连的所有连接也将一并被删除。

3.将节点连接到数据流中

上面介绍了将节点添加到数据流区域的方法,然而要使节点真正发挥作用,需要把节点连接到数据流中。以下有3种方法可将节点连接到数据流中:

(1)双击节点。首先选中数据流中要连接新节点的节点(起始节点),然后双击选项板区中要添加到数据流的节点(目标节点),这样新节点会出现在数据流区域,并自动建立从起始节点到目标节点的连接。

(2)通过Alt键连接。首先在数据流中选中连接起始节点,按住Alt键不放,然后用鼠标将起始节点拖曳到目标节点后放开,连接便自动生成。

(3)手动连接。右击待连接的起始节点,从弹出的快捷菜单中选择“连接…”命令,然后用鼠标单击目标节点,连接便自动生成。

需要注意的是,并不是任何两个节点之间都可以建立连接。

4.绕过数据流中的节点

当暂时不需要数据流中的某个节点时可以绕过该节点。在绕过它时,如果该节点既有输入节点又有输出节点,那么它的输入节点和输出节点便直接相连;如果该节点没有输出结点,那么绕过该节点时与这个节点相连的所有连接便被取消。

方法:按住Alt键不放,然后双击数据流中需要绕过的节点,如下图所示。

Image:绕过节点前后对比.jpg

5.将节点插入已存在的连接中

当需要在两个已连接的节点中再插入一个节点时,可以用鼠标将连接拖到要插入的节点上,即可将节点插入到连接中,如图所示。同时原来两个节点间的连接被删除。

Image:在连接中插入新节点.jpg

6.删除连接

当某个连接不再需要时,可以通过以下两种方法将其删除:

(1)选择待删除的连接,右击,从弹出的快捷菜单中选择“删除连接”命令。

(2)选择待删除连接的节点,按F3键,删除所有连接到该节点上的连接。

7.数据流的执行

数据流构建好后要通过执行数据流数据才能从读入开始流向各个数据节点。执行数据流的方法有以下3种。

(1)单击菜单栏中的按钮,数据流区域内的所有数据流将被执行。

(2)先选择要输出的数据流,再单击菜单栏中的按钮,被选的数据流将被执行。

(3)选择要执行的数据流中的输出节点,右击,在弹出的快捷菜单中选择“执行”命令,执行被选中的节点。提出,他将数据流定义为“只能以事先规定好的顺序被读取一次的数据的一个序列”。

代码签名证书是保护开发者的劳动成果,给自己开发的软件签名的证书,保证代码在签名之后不被恶意篡改。用户可通过对代码的数字签名来标识软件来源,辨别软件开发者的真实身份。GDCA的代码签名证书支持多种代码签名,已通过WEBTRUST国际认证。

相关文章

  • 浅谈数据流

    姓名:周君会 学号:17011210526 转载自: http://www.jianshu.com/p/b1...

  • 浅谈数据流水线

    当下我们听过很多热门的技术名词,例如:机器学习模型、推荐系统、高管驾驶舱、BI等等,在这些技术背后一个关键的角色就...

  • 单项数据流与Vuex

    单项数据流 单向数据流(Unidirectional data flow)方式使用一个上传数据流和一个下传数据流进...

  • 2020-07-02

    浅谈 浅谈模块设计宏内核 浅谈接口设计Flags 浅谈稳定性设计重试 浅谈人员业务结构设计矩阵式 浅谈接口设计 |...

  • 编译器笔记48-代码优化-数据流分析

    数据流分析(data-flow analysis) 数据流分析一组用来获取程序执行路径上的数据流信息的技术 数据流...

  • Redux异步模式

    同步数据流 (1)createStore默认创建的Redux store只支持同步数据流。 异步数据流 (1)使用...

  • 浅谈Filecoin(二)

    浅谈Filecoin(二) 浅谈Filecoin(一)链接:浅谈Filecoin(一) (Verifiable)M...

  • 常见vue面试题

    1. 解释单向数据流和双向数据绑定单向数据流: 数据流是单向的。数据流动方向可以跟踪,流动单一,追查问题的时候可以...

  • Dataflow

    拥有数据流的对象: 项目数据流:整个项目最顶级的数据流,只能单向向下连接其他阶层的数据流,不能反向连接,修改方法M...

  • 浅谈runtime关联

    浅谈runtime关联 浅谈runtime关联

网友评论

    本文标题:浅谈数据流

    本文链接:https://www.haomeiwen.com/subject/hxpvpxtx.html