【原创】SystemVerilog中的多态和虚方法

本文详细探讨了SystemVerilog中的多态和虚方法。通过实例展示了子类如何继承并重写父类的方法,以及父类句柄如何访问子类重写的方法。重点介绍了虚方法的概念,指出虚方法是实现多态的关键,强调了声明虚方法的注意事项和多态在SystemVerilog中的应用。
摘要由CSDN通过智能技术生成

封装可以隐藏实现细节,使代码模块化,继承可以扩展已经存在的代码模块,目的都是为了代码重用。多态是为了实现接口的重用。在SystemVerilog中,子类和父类之间多个子程序使用同一个名字的现象称为SystemVerilog的“多态(polymorphism)”特征。子类从父类扩展创建之后,子类就继承了父类的属性和方法,这是SystemVerilog的继承特征,但是这个继承特征需要遵循一定的规则:

v 子类继承父类的所有属性(local除外)和方法;

v 子类可以添加新的属性和方法;

v 子类可以重写父类中的属性和方法;

v 如果父类的一个方法被重写,子类必须保持和父类的原定义有一致的参数;

v 子类可以通过super(不能使用super.super方式)操作符引用父类中的方法和成员;

v 被声明为local的属性或方法只能对自身可见,而对于外部和子类不可见;

v 被声明为protected的属性或方法,对外部不可见,对于自身和子类可见;

我们知道,因为继承的特性,子类可以访问父类的属性,当子类对父类的方法进行重写,子类句柄访问的是重写后的方法。那么当父类句柄指向子类时,是否可以通过父类句柄访问子类的属性呢?默认情况下,父类句柄是不能直接访问子类的方法或者重写父类的方法。

【示例】

图片

【仿真结果】

  • 7
    点赞
  • 47
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

硅芯思见

你的鼓励是我创作的最大源泉

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值