SV学习笔记(十三)-多态、类型转换

多态-虚方法

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()系统函数可以将父类举殡转换为子类句柄,只要该父类句柄指向的时子类的对象
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值