封装可以隐藏实现细节,使代码模块化,继承可以扩展已经存在的代码模块,目的都是为了代码重用。多态是为了实现接口的重用。在SystemVerilog中,子类和父类之间多个子程序使用同一个名字的现象称为SystemVerilog的“多态(polymorphism)”特征。子类从父类扩展创建之后,子类就继承了父类的属性和方法,这是SystemVerilog的继承特征,但是这个继承特征需要遵循一定的规则:
v 子类继承父类的所有属性(local除外)和方法;
v 子类可以添加新的属性和方法;
v 子类可以重写父类中的属性和方法;
v 如果父类的一个方法被重写,子类必须保持和父类的原定义有一致的参数;
v 子类可以通过super(不能使用super.super方式)操作符引用父类中的方法和成员;
v 被声明为local的属性或方法只能对自身可见,而对于外部和子类不可见;
v 被声明为protected的属性或方法,对外部不可见,对于自身和子类可见;
我们知道,因为继承的特性,子类可以访问父类的属性,当子类对父类的方法进行重写,子类句柄访问的是重写后的方法。那么当父类句柄指向子类时,是否可以通过父类句柄访问子类的属性呢?默认情况下,父类句柄是不能直接访问子类的方法或者重写父类的方法。
【示例】
【仿真结果】