类的三要素:封装、继承、多态
概述
举例:
答案:D;color和is_good外部均不能访问。color子类能访问,is_good子类不能访问。
验证环境中的案例1
验证环境中的案例2
成员的覆盖
如图所示,子类中定义了def = 200,父类中也有def = 100。
答案:D。
-
而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;?
|