如何理解派生类的构造函数

文章目录

  • 前言
  • 一、派生类的构造函数
  • 二、派生类的构造函数举例
  • 总结


前言

在class中,有的时候有构造函数new,有的时候又没有构造函数new,本文主要记录一下,派生类的构造函数的执行过程,帮助更好的理解class的构造函数。


一、派生类的构造函数

当派生类中没有构造函数时,VCS会自动插入一个构造函数new,并执行其父类中的构造函数super.new();
当派生类中有构造函数时,systemverilog期望构造函数的第一行代码,就是去执行父类的构造函数super.new(),同时保证正确的参数传递,否则会报语法错误,如果用户没有去调用super.new(),那么编译器会自动插入一个没有参数的父类构造函数调用,如果出现参数不匹配,也会报语法错误。
如何理解派生类的构造函数_第1张图片

二、派生类的构造函数举例

示例代码如下,A作为基类,构造函数中带了一个参数传递,B是A的子类,B中间没有构造函数,C是B的子类,C中的构造函数带了一个参数传递,测试代码中,实例化了C,并给了参数,问该代码能否编译成功呢?
如何理解派生类的构造函数_第2张图片
答案是不能正常编译,会报语法错误。原因如下所示,C中VCS会在构造函数的第一行中,插入super.new(),B中VCS会插入构造函数,并无参调用super.new(),所以,可以看到,C通过super.new()调用B的构造函数,没啥问题,但是B通过super.new()调用A的构造函数的时候,缺失一个参数,所以在编译过程会报语法错误。
如何理解派生类的构造函数_第3张图片
修改方案如下所示,我们可以手动给C和B加入构造函数及其调用,并将参数传递过去。
如何理解派生类的构造函数_第4张图片


总结

本文主要记录派生类的构造函数执行过程。

你可能感兴趣的:(systemverilog,构造函数,new)