SystemVerilog

数据类型


  1. 动态数组: 声明时不需要指定个数
  2. 关联数组区别于动态数组的地方: 索引方式;

关联数组:
integer as_mem [integer];

  1. queue name[$]
    Each element in a queue is identified by an ordinal number that represents its position within the queue, with 0 representing the first, and $ representing the last.
  • 0 : Used to access first element of queue
  • $ : Used to access last element of queue
  • {} : Used along with first and last operator to add/delete elements
  1. queue ::

并行


  1. fork ... join
fork
  begin
  ...
  end

  begin//每个begin end内的代码串行;各个begin之间代码并行
  ...
  end

join
fork
  task  //task or function 并行
  function

join
  • join 等所有分支结束再开始执行后续代码
  • join any任意一个分支结束即开始执行后续代码,后续代码可能也fork中的未完成的分支的代码并行执行
  • join none开始执行各个分支之后即开始执行后续代码

函数


  1. task/function
  • task 可以加延迟或比如说等一个上升沿
  • function 不能延迟
  • task 没有返回值,function可以由返回值
task doInit (input bit[3:0] count, delay);   
  automatic reg[7:0] a; 
  if(count > 5)begin
     $display("@%g Returning from task",$time); 
      return
   end
   #(delay)$display("@%g Value passed is %d",$time, count);  //task中插入延迟 
endtask
  1. task/funciton port

    • input : copy value in at beginning
    • output : copy value out at end
    • inout : copy in at beginning and out at end
    • ref : pass reference
  2. Argument Passing

    • Pass by value
    • Pass by reference
    • Pass by name
    • Pass by position
    • default values
    • Optional arguments.
  3. ref 相当于指针;

进程间通信


  1. mailbox 可以传递参数,像fifo
  2. semaphores 如同令牌/许可证 put(3) 可以 get(1),也可以get(3)
    这里的值并不是判断put/get的值相等才能执行;
  • new()
  • get()
  • put()

包定义


  1. pakage相等于module,c的函数; 里边的变量在pakage内部为局部变量;作用是限定变量的scope;
    编译空间中存放不在任何一个pakage的代码 , 编译空间相当于一个特殊的pakage

class


  1. class 如同struct,可以嵌套;
int a; //int 类型,a为int类型的变量
class_name c_o; //class_name class类型,c_o 是一个object
              //c_o是一个handle 没有分配内存空间;
  1. 类成员变量static,所有对象共享一个属性,相当于全局变量,方便参数传递;
  2. 类的方法也可以是静态的,所有的类都可以直接调用其他类的静态方法,即使调用没有初始化的对象也是合法的,但是静态方法不能调用非静态成员,如果调用会产生编译错误。静态方法不能为虚方法。另外需要注意区分的是静态方法和一般方法但是变量为静态生命周期。
  3. this只能用在非静态的成员函数中

指针复制/浅拷贝/深拷贝

  1. 指针复制

    class_name a;      
    class_name b;       
    a=new();       
    b=a;  //b,a指向同一个内存空间
    
  2. 浅拷贝

  3. 深拷贝
    代码需要自己写

浅拷贝是指源对象与拷贝对象共用一份实体,仅仅是引用的变量不同(名称不同)。对其中任何一个对象的改动都会影响另外一个对象。举个例子,一个人一开始叫张三,后来改名叫李四了,可是还是同一个人,不管是张三缺胳膊少腿还是李四缺胳膊少腿,都是这个人倒霉。
深拷贝是指源对象与拷贝对象互相独立,其中任何一个对象的改动都不会对另外一个对象造成影响。举个例子,一个人名叫张三,后来用他克隆(假设法律允许)了另外一个人,叫李四,不管是张三缺胳膊少腿还是李四缺胳膊少腿都不会影响另外一个人。

class baseA ;
    integer j = 5;
endclass

class B ;
    integer i = 1;
    baseA a = new;
endclass

module test();
  //xtndA xtnd1;
  baseA base2, base3;
  int test;   
  initial begin
    B b1    = new;    // Create an object of class B
    B b2    = new b1; // Create an object that is a copy of b1
    b2.i    = 10;     // i is changed in b2, but not in b1
    $display("b1.i = %0d",b1.i);     
    b2.a.j  = 50;     // change a.j, shared by both b1 and b2
    $display("b1.a.j = %0d",b1.a.j);
  end 
endmodule

继承

  1. 把通用的代码放到父类
  2. 继承重载:当子类的方法需要和父类不同时使用;

super

  1. 当在子类中需要对父类的属性进行操作,或者调用父类的方法可以使用super指针直接指向该成员

虚函数

  • 父类中需要多态的方法必须被声明成virtual以便被覆盖
class BasePacket;
  int A = 1;
  int B = 2;
  function void printA;
    $display("BasePacket::A is %0d", A);
  endfunction : printA
  
  virtual function void printB;
    $display("BasePacket::B is %0d", B);
  endfunction : printB
endclass : BasePacket
  
class My_Packet extends BasePacket;
  int A = 3;
  int B = 4;
  function void printA;
    $display("My_Packet::A is %0d", A);
  endfunction: printA
  virtual function void printB;
    $display("My_Packet::B is %0d", B);
  endfunction : printB
endclass : My_Packet
  
module test();
  BasePacket P1 = new;
  My_Packet P2 = new;
  initial begin
    P1.printA; 
    P1.printB; 
    P1 = P2;   
    P1.printA; 
    P1.printB; // 此处调用子类函数 
    P2.printA; 
    P2.printB; 
  end
endmodule

数据的隐藏与封装

  1. 一个local成员只能被当前类中的方法访问,即使是其子类也无法访问local成员。
  2. protected成员和local成员什么相似,只是其对于子类是可见的。

类的常量

  1. 在SystemVerilog中也可以通过在变量前面加上const来声明一个只读属性;
  • 全局常量,在声明变量时就初始化了初值,除了这里以外的任何地方都不允许再更该其值。
  • 实例常量, 实例常量在声明的时候只有const关键字而没有初值,只在相应的构造函数中将其初始化。
  • 全局常量也可以被声明为static,对所有的对象来说是共用一个这样的变量的,而实例常量却不能声明为static,因为静态常量不能在构造函数中赋值。

多态

  1. 注意多态的实现需要四个条件:有继承,有重写,父类指针指向子类对象,还有有父类函数的virtual。
  • SV所提供的机制被称为单继承,也就是说,每一个子类都由一个单一的父类继承而来,父类的方法可以被覆盖或隐藏。不支持同一类域中同名不同参的方法重载。父类中需要多态的方法必须被声明成virtual以便被覆盖。普通类的virtual方法必须被具体实现,virtual类的方法可以没有具体的实现。virtual类不能被实例,只能被继承。super关键字在一个子类的内部使用,可以用来引用其父类的成员。

封装


为了减少代码之间的依赖关系

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351

推荐阅读更多精彩内容

  • 10#数据类型 合并数组和非合并数组 合并数组:存储方式是连续的,中间没有闲置空间。例如,32bit的寄存器,可以...
    constant007阅读 32,788评论 0 18
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,604评论 18 399
  • *面试心声:其实这些题本人都没怎么背,但是在上海 两周半 面了大约10家 收到差不多3个offer,总结起来就是把...
    Dove_iOS阅读 27,135评论 30 470
  • 每一位冷性情女子都不是生来就是如此,只是受的伤多了,也就渐渐长出了保护自己防御外界的金盔铁甲。 幼时太渴望得到父母...
    婉言1228阅读 456评论 0 2
  • 换一种方式来记录旅行,来铭记我那个大大的梦想—一边文字一边旅游。也许有人在默默的嘲笑着它犹如镜中花水中月。但是没有...
    浅草樱落阅读 373评论 2 0