关键词“virtual”在system Verilog的作用及用法

本文详细解析SystemVerilog中的virtual关键字在封装、继承和多态中的应用,涉及virtualinterface、task/function和class的使用,以及UVM中的虚类示例。理解并掌握如何利用virtual实现灵活的接口设计和类的扩展。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、“virtual”的作用

面向对象编程(OOP)三大特性(封装,继承,多态)中的 多态 在SystemVerilog中一般通过 “virtual” 关键字实现。通过virtual声明的类,接口,任务与函数,其本身自带一些方法或者函数。后续的例化或者扩展可以对原有的内容进行增加或者修改,从而实现同一函数不同方法的多种形态。

二、“virtual”在system Verilog中的用法

其主要应用场景在virtual interface,virtual task/function以及virtual class 中。

1. virtual interface

  • 在interface定义时,如果不使用关键字 “virtual” 那么在多次调用该接口时,在其中的一个实例中对接口中某一信号的修改会影响其他实例接口;如果使用了 “virtual” 关键字,那么每个实例是独立的。
  • 习惯上在声明interface时均添加 "virtual"关键字。

2. virtual task/function

  • 用于OOP思想的继承使用。即子类可以继承父类的成员及方法。当定义了virtual时,在子类中调用某task/function时,会先查找在子类中是否定义了该 task/function,如果子类没有定义,则在父类中查找。未定义virtual时,只在子类中查找,没有定义就是编译器报错。
  • 如果某一class会被继承,则用户定义的task/function(除new(),randomized(),per_randomize(),pose_randomize()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值