uvm重载成员中的函数
时间:10-02
整理:3721RD
点击:
class agt;
drvdrv_inst;
endclass
drv中有任务drive;
class drv;
virtual task drive();
endclass
现在我从agt派生一个子类agt1, 在agt1.sv中想重载agt1.drv.drive()任务,该怎么弄呢?我不想再定义一个drv的子类。
我像下面这样报错了
Class agt1 extend agt;
Task drv::drive();
Endtask
Endclass
谢谢各位大神了!小弟刚学uvm
drvdrv_inst;
endclass
drv中有任务drive;
class drv;
virtual task drive();
endclass
现在我从agt派生一个子类agt1, 在agt1.sv中想重载agt1.drv.drive()任务,该怎么弄呢?我不想再定义一个drv的子类。
我像下面这样报错了
Class agt1 extend agt;
Task drv::drive();
Endtask
Endclass
谢谢各位大神了!小弟刚学uvm
这个其实和UVM没关系吧。 跟OOP相关。
不在drv的子类去重载, 好像没有更好的办法吧。
期待大神解答
同问
drv不是一个单独的class吗?
为什么不在agt1里直接例化这个drv?
问题好像没有说清楚
SV里做不到的。为什么你愿意建新的agt class而不愿建新的drv class?
不太容易,用父类的方法子类的实现可以解决部分问题,但是不知道想得到什么样的效果。