zoukankan      html  css  js  c++  java
  • Chisel3

     
    介绍创建模块顺序逻辑的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
     
    批量连接的调用过程如下:
     
     
     
     
     
  • 相关阅读:
    多线程之volatile关键字
    多线程具体实现
    多线程的概述
    Linux基本目录机构
    Java13新特性
    CF1316D【Nash Matrix】(dfs+构造+思维)
    ego商城项目学习总结+出现问题及解决
    java.lang.OutOfMemoryError: GC overhead limit exceeded之tomcat7优化
    jsp在tomcat中更新不起作用
    js取值及赋值
  • 原文地址:https://www.cnblogs.com/wjcdx/p/10224281.html
Copyright © 2011-2022 走看看