介绍创建模块顺序逻辑的connect命令。
0. 这里先简单对 "=" 和 ":="做一个讨论。
假设 a & b 的结果输出到一个匿名变量,记为anonymousVariable。
a & b的用法有两种:
1) c := a & b
":="的意思为连接。变量c作为下游,连接到anonymousVariable,接收其值。即anonymousVariable的值的变化会传播到下游c中。
2) c = a & b
"="的意思是赋予。之所以不说赋值,是因为更多情况下赋予的不是值,而是引用。
这里就是把anonymousVariable赋给c。就相当于给a & b的输出这个匿名变量取了一个名字,叫做c。
因为anonymousVariable是匿名的,所以这里使用c来简化引用也是有意义的。
总结下来:
1) 两者的区别在于,一个是匿名变量本身,一个是匿名变量的下一级连接。
2) ":="是连接到的意思(connect to);
3) "="也不是赋值,而是赋引用,取名字或者起别名的意思;
1. connect
连接符号为:
":=" 使用connect方法实现:
final def := (that: Data)(implicit sourceInfo: SourceInfo, connectionCompileOptions: CompileOptions): Unit = this.connect(that)(sourceInfo, connectionCompileOptions)
connect定义在Data类中:
sink为下游,source为上游:
2. bulkConnect
批量连接的调用过程如下: