如何理解system verilog 中的virtual函数

举一个例子:

class bird;//定义一个基类

virtual function print() display("I am a bird!");endfunction//定义一个virtual函数

endclass:bird

class red_bird extends bird;//定义一个子类

function print() display("I am a red bird!");endfunction

endclass :red_bird

initial begin

bird bird_h = new();//创建基类对象

red_bird red_bird_h = new();//创建子类对象

bird_h.print();//调用基类的print函数,打印结果为 "I am a bird!"

red_bird_h.print();//调用子类的print函数,打印结果为 "I am a red bird!"

bird_h = red_bird_h;//将基类的指针指向子类的对象

bird_h.print();//再次调用print函数,打印结果为"I am a red bird!"

//如果将基类中print函数前的virtual关键字去掉,再次调用bird_h.print(),会得到哪个?答案是"I am a bird"

//结论:对一个virtual函数,通过指针被调用时,是由这个指针指向的对象的决定调用哪个具体的函数,而不是指针的类型决定.反之,如果记类函数声明时没有加virtual关键字,那么该函数被调用时是由指针类型决定应该调用哪个具体函数.

end

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值