多态-虚方法
module tb;
class BasePacket;
int A= 1;
int B = 2;
function void printA;
$display("BasePacket::Ais &d",A);
endfunction : printA
virtual function void printB;
$display("BasePacket::Bistd",B);
endfunction : printB
endclass : BasePacket
class My Packet extends BasePacket;
int A= 3;
int B = 4;
function void printA;
$display("My_Packet::Ais id",A);
endfunction: printA
virtual function void printB;
$display("My_Packet::Bis id",B);
endfunction : printB
endclass : My Packet
BasePacket Pl = new;
My_Packet P2 = new;
initial begin
Pl.printA;//displays 'BasePacket::Ais 1'
Pl.printB;//displays 'BasePacket::Bis 2'
P2.printA;//displays 'My_Packet::A is 3'
P2.printB;//displays'My_Packet::Bis 4'
Pl = P2; // Pl has a handle to a My packet object
Pl.printA; // displays 'BasePacket::A is 1'
p1.printB; // displays 'BasePacket::A is 4'
// p1是父类的句柄,指向的是子类的对象,执行printB的时候先去父类中找,找到printB方法有个virtual的关键字,表示这是一个虚方法,会继续往子类中查找是否有同名方法,如果有,执行子类的方法,如果没有执行父类的方法
end
endmodule
类型转换
静态转换
-
静态转换操作符不对转换值进行检查
-
转换时指定目标类型,并在要转换的表达式前加上单引号
-
Verilog对整数和实数类型,或者不同位宽的向量之间进行转换
int i; real r; i = int'(10.0-0.1); r = real'(42);
动态转换
- 可以将子类的句柄赋值给父类的句柄
- 父类的句柄赋值给子类的句柄时,编译会报错
$cast()
系统函数可以将父类举殡转换为子类句柄,只要该父类句柄指向的时子类的对象