本篇内容介绍了“virtual method怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
method是class中子程序,包括function和task。
当直接将子类赋值给父类,再调用父类中的方法时,实际调用的还是父类中的方法。除非该方法被virtual声明,子类就可以覆盖父类中的方法。
这是systemverilog面向对象语言的多态(polymorphism)特征。
用关键字virtual声明的SystemVerilog方法称为virtual methods。
Virtual Functions模板:
virtual function function_name;//Function definitionendfunction
Virtual Tasks模板:
virtual task task_name;//task definitionendtask
在示例1中,父类内部的方法声明时没有virtual关键字,赋值后b_c.display()将调用父类的方法。
class base_class; function void display; $display("Inside base_class"); endfunctionendclassclass extended_class extends base_class; function void display; $display("Inside extended class"); endfunctionendclass module virtual_class; initial begin base_class b_c; extended_class e_c; e_c = new(); b_c = e_c; b_c.display(); endendmodule
输出:
Inside base_class
在示例2中,父类内部的方法声明时加上virtual关键字,赋值后b_c.display()将调用子类的方法。
class base_class; virtual function void display; $display("Inside base_class"); endfunctionendclassclass extended_class extends base_class; virtual function void display; $display("Inside extended class"); endfunctionendclass module virtual_class; initial begin base_class b_c; extended_class e_c; e_c = new(); b_c = e_c; b_c.display(); endendmodule
输出:
Inside extended class
pure virtual method
virtual method:这是一种可以在派生类中继承的方法,该方法可以在派生类中被覆盖。
pure virtual method:这是在Virtual Class(可以扩展但不能实例化的类,仅作为基础类或原型类)中声明的virtual method。在派生类必须具有该方法的具体实现。
pure virtual method只能是原型或模板。
pure virtual method内部不能具有任何实现。
pure virtual method不允许使用“ end”关键字,例如endfunction / endtask。
virtual class base_class; pure virtual function void display;endclassclass extended_class extends base_class; virtual function void display; $display("Inside extended class"); endfunctionendclassmodule virtual_class; initial begin extended_class e_c; e_c = new(); e_c.display(); endendmodule
如果有一个带有pure virtual method的Virtual Class,则必须在子类中对其具体实现。但对于virtual method,可以覆盖也可以不覆盖。
“virtual method怎么使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://my.oschina.net/u/4579683/blog/4353759