SV精通3-③类的继承、句柄的使用

类的三要素:封装、继承、多态
概述
举例:
答案:D;color和is_good外部均不能访问。color子类能访问,is_good子类不能访问。

验证环境中的案例1
  • BadTr继承了父类的成员变量,又新定义了成员变量和方法。默认二者的方法没有关系,但是通过了super来继承了父类的calc_crc()和display(),两个方法。
  • 不使用super.calc_crc()的话,使用this.calc_crc()在当前子类找calc.crc(),找不到就自动到父类中寻找calc.crc(),结果是找到了。说明this和super有区别也有联系。

验证环境中的案例2
  • 默认情况下,子类继承语句之后,新定义了一个与父类的方法,通常喜欢把父类的方法写在前面,开辟空间。
  • 成员变量默认值赋予之后,才会进入new函数中执行剩下的初始化代码。如下图所示,先赋初值,再执行new函数的代码,进行初始化。

成员的覆盖
如图所示,子类中定义了def = 200,父类中也有def = 100。
答案:D。
  • 子类继承父类后,可以指向父类中public的全部成员变量和方法,因此子类可以指向父类的def和自身子类的def,但是使用wr.def,那么优先指向子类中的def,为200。
  • 而t = wr之后,虽然说把wr全部给了t,此时wr和t都指向同一个对象(该对象继承了父类的成员变量def)但是t作为父类,依旧只能指向从wr那赋值而来的两个def中父类的def,因此def=100。
  • wr = t;这样的赋值会报错,因为父类句柄的空间更小,而子类句柄的空间更大 。t父类小三角没办法扩大成一个大三角。wr = t之后使用wr.def这句话是没办法实现的,会报错,因为此时wr指向t的内存空间是小三角形,而原本的子类的def在扩展的小三角形之外的空间内,因此没办法取到,不能扩大为一个大三角形。
  • 即,父类句柄不能直接赋值给子类句柄(用“=”是错误的),而是要使用$cast()语句,把父类句柄转化为子类句柄。
  • $cast(wr,t);即把父类句柄转化为子类句柄。如果t指向了大三角形则返回1,反之则为0;

句柄的使用
答案:C;会报错,因为Transaction tr默认tr方向为input,只是把null通过create传递给了tr,但是tr为input并不会输出,因此得不到t.addr的值。
因此修改如下:修改参数列表ref Transaction tr或者inout Transaction tr。

句柄的动态修改
答:C;只创建了一个对象,只对一个对象中的数据进行操作,push_back(t)放的是句柄,把句柄放入了队列,因此三个值都是一样的,因为随着循环t.addr一直在变化,句柄也一直指向这个变化的t.addr。
0 << 2 = 0、1 << 2 = 4、2 << 2 = 8; 
  • 3
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值