System Verilog中的OOP

System Verilog中的OOP



前言

super函数:扩展类中可以通过super前缀调用基类中的函数
可以调用上一层类的成员,但是SV不允许使用类似super.super.new的方式进行多层调用
将类中的子程序定义成虚拟的,这样就可以在扩展类中重新定义,这一点适用于所有的任务和函数,除了new函数

属性:OOP中类的变量
原始类:父类或者超类
拓展类:派生类或者之类
基类:不从任何其它类派生的道德类
子程序的原型:指明了参数列表和返回类型的第一行

1、定制构造函数

当调用new函数例化一个对象的时候,是在为该对象申请一个新的内存块来保存对象的变量。构造函数除了分配内存外,他还会初始化变量(默认情况下,二值变量设为0,四值变量设为X)。可以通过自定义new函数将默认值设为想要的数值。new函数本身不能有返回值,因为构造函数总是返回一个指向类对象的句柄,其类型就是类本身。
简单的自定义new()函数:

class transaction;
	logic [31:0] addr,crc,data[
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值