python中关于类与对象的测试题_小甲鱼Python第039讲:类和对象:拾遗 | 课后测试题及参考答案...

测试题

0.什么是组合(组成)?

Python继承机制很有用,但容易把容易代码复杂化以及依赖隐含继承。因此,经常的时候,我们可以使用组合代替。在Python里组合其实很简单,直接在类定义中把需要的类放进去实例化就可以了。

eg:

1 #乌龟类

2 classTurtle:3 def __init__(self,x):4 self.num =x5 #鱼类

6 classFish:7 def __init__(self,x):8 self.num =x9 #水池类

10 classPool:11 def __init__(self,x,y):12 self.turtle = Turtle(x)#组合乌龟类进来

13 self.fish = Fish(y)#组合鱼类进来

14

15 defprint_num(self):16 print("水池中总共有乌龟%d只,小鱼%d条。" %(self.turtle.num,self.fish.num))17

18 >>>pool = Pool(4,5)19 >>>pool.print_num()

1.什么时候用组合,什么时候用继承?

根据实际应用场景确定。简单的说,组合用于“有一个”的场景中,继承用于“是一个”的场景中。例如,水池里面有一个乌龟,天上有一只小甲鱼,这些适合使用组合。青瓜是瓜,女人是人,鲨鱼是鱼,这些就应该使用继承啦。

2.类对象实在什么时候产生?

当你这个类定义完的时候,类定义就变成了类对象,可以直接通过“类名.属性”或者“类名.方法名()”引用或使用相关的属性或方法。

3.如果对象的属性跟方法名字相同,会怎样?

如果对象的属性和方法名相同,属性就会覆盖方法。

1 >>> classC:2 defx(self):3 print("X-man")4

5

6 >>> c =C()7 >>>c.x()8 X-man9 >>> c.x = 1

10 >>>c.x11 1

12 >>>c.x()13 Traceback (most recent call last):14

15 File "", line 1, in

16 c.x()17 TypeError: 'int' object is not callable

4.请问有效类定义中哪些是类属性,哪些是实例属性?

1 classC:2 num =03 def __init__(self):4 self.x =4

5 self.y = 5

6 C.count = 6

num和count是类属性(静态变量),x和y是实例属性。大多数情况下,应该考虑使用实例属性,而不是类属性(类属性通常仅用来跟踪与类相关的值)

5.请问以下代码中,bb对象为什么调用printBB()方法失败?

1 >>> classB:2 defprintB():3 print("no zuo no die")4 >>> b =B()5 >>>b.printB()6 Traceback (most recent call last):7 File "", line 1, in

8 b.printB()9 TypeError: printB() takes 0 positional arguments but 1 was given

因为Python严格要求方法需要有实例才能调用,这种限制其实就是Python所谓的绑定概念。所以Python会自动把bb对象作为第一个参数传入,所以才会出现TypeError:"需要0个参数,但实际传入了1个参数"。

1 >>> classB:2 defprintB(self):3 print("no zuo no die")4

5

6 >>> b =B()7 >>>b.printB()8 no zuo no die

动动手:

0.思考这一讲我学习的内容,请动手在一个类中定义一个变量,用于跟踪该类有多少个实例被创建(当实例化一个对象,这个变量+1,当销毁一个对象,这个变量自动-1)

1 >>> classD:2 count =03 def __init__(self):4 D.count += 1

5

6 def __del__(self):7 D.count -= 1

8

9

10 >>> a =D()11 >>> b =D()12 >>>D.count13 2

14 >>> c =D()15 >>> d =D()16 >>>D.count17 4

18 >>> delc19 >>>D.count20 3

1 classStack:2 def __init__(self,start=[]):3 self.stack =[]4 for each instart:5 self.push(each)6 defisEmpty(self):7 return notself.stack8 defpush(self,value):9 self.stack.append(value)10 deftop(self):11 if notself.stack:12 print("栈为空")13 else:14 return self.stack[-1]15 defbottom(self):16 if notself.stack:17 print("警告:栈为空。")18 self.base =self.stack[0]19 defpop(self):20 if notself.stack:21 print("栈为空")22 else:23 return self.stack.pop()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值