完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
扫一扫,分享给好友
最近在学习systemverilog,读的是经典教材《SystemVerilog for Verification》Chris Spear写的。8.5.1节中对象的复制搞不明白是啥意思。代码如下:
1. 首先在基类中,采用使用copy_data函数的写法 class Transaction; rand bit[31:0] src, dst,data[8]; bit[31:0] crc; virtual function void copy_data(input Transaction tr); copy.src=src; copy.dst=dst; copy.data=data; copy.crc=crc; endfunction virtual function Transaction copy(); copy=new(); copy_data(copy); endfunction endclass 2. 然后再定义一个使用copy_data函数的扩展类 class BadTr extends Transaction ; rand bit bad_crc; virtual function void copy_data(input Transaction tr); BadTr bad; super.copy_data(tr); $cast(bad,tr); bad.bad_crc=bad_crc; endfunction virtual function Transaction copy(); BadTr bad; bad=new(); copy_data(bad); return bad; endfunction endclass:BadTr 哪个大神能帮忙一句句的解释一下?尤其是扩展类那里,完全晕了。多谢! |
|
相关推荐
1个回答
|
|
翻了几天前的帖子,还是没有人答,哎,结果都是自己慢慢摸索出来的。继续自答。。
个人觉得: class Transaction; rand bit[31:0] src, dst,data[8]; bit[31:0] crc; virtual function void copy_data(input Transaction tr); copy.src=src; copy.dst=dst; copy.data=data; copy.crc=crc; 中的copy,应该改为tr。是书中写错了。 |
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
1421 浏览 1 评论
1215 浏览 0 评论
矩阵4x4个按键,如何把识别结果按编号01-16(十进制)显示在两个七段数码管上?
1426 浏览 0 评论
913 浏览 0 评论
2229 浏览 0 评论
1432 浏览 35 评论
5616 浏览 113 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-22 22:31 , Processed in 0.386293 second(s), Total 43, Slave 34 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号