【第039讲心得】【组合、继承和拾遗】
本帖最后由 heidern0612 于 2018-12-21 09:38 编辑写心得的过程都是自我思考的过程,借鉴了很多论坛大神的互联网大佬的经验,仓促间难免出错,如有错误,恳请指出,感激不尽。
总算知道为什么那么多写日志的都更到38讲附近都不更了,突然消失了似的。
因为类实在是太TM难了,学完类感觉脑细胞死了一大堆有木有?
好不容易感觉自己跨过一个坎,下面又一大堆不明白的,死了算逑。
真怕自己也哪一天死在学习的路上,最近烦心事比较多,比较忙,做什么似乎进展都不大。
于是放松清闲了几天,翻了翻之前买的几本书,重新学了下python。
没有顿悟的赶脚,但是思路清晰了不少,借帖子机会写下来。
p.s:最近代码基本没敲,几乎都在看书中度过,学不下去类的时候,看看类周边的介绍,似乎帮助也不少。
老师的课后习题我就不说啥了,前面都挺简单的,老师讲的也基本都是常识。
主要说说最后一题,附上我自己的见解。
class Stack:
def __init__(self, start=[]):
self.stack = []
for x in start:
self.push(x)
def isEmpty(self):
return not self.stack # 假定列表为空,非(空),结果返回True。
def push(self, obj):
self.stack.append(obj)
def pop(self):
if not self.stack: #原理同上,假定列表为空,非(空),返回True。
print('警告:栈为空!')
else:
return self.stack.pop()
def top(self):
if not self.stack:
print('警告:栈为空!')
else:
return self.stack[-1] #index倒1,最后一位元素。
def bottom(self):
if not self.stack:
print('警告:栈为空!')
else:
return self.stack
1、为啥开始要赋值个start为空列表的默认值,而下面又用了个self.stack变量为空的列表?
①、形参和实参的关系。定义类时start是形参,实例化之后self.stack就是实参了;
②、因为是列表,下面操作的一系列相关都是针对列表的操作(增减),所以需要复制一份列表出来;
2、为啥要定义栈为空?
因为一系列的增减都是针对列表的,当列表为空的时候,是没办法索引的。
3、为啥要用个for循环?直接self.push(x)不行吗?
for循环是为了保证你实例化时传入非空列表进行迭代用。
好像有点绕,这么说吧。
传入的实参分两种情况,一种是空列表【 】;一种是带元素的列表,如【1,2,3,4,5】。
c=Stack()
print(c.stack)
后一种情况想要压栈的话,就必须一个个压进去,for循环的作用就在这了。
解释的很到位,谢谢 大佬,能不能讲讲类中组合的语法?我是真的憔悴了
比如
class Turtle:
def __init__(self,x):
self.num = x
calss Pool:
def __init__(self,x):
self.turtle = Turtle(x)
运用组合时“self.turtle=Turtle(x)”里面的x,究竟是哪个类里面的x?怎么赋值过程是怎样的啊?
页:
[1]