heidern0612 发表于 2018-12-21 09:08:15

【第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循环的作用就在这了。

bluesky0476 发表于 2020-3-14 16:55:35

解释的很到位,谢谢

霓虹巨人 发表于 2020-4-5 22:05:15

大佬,能不能讲讲类中组合的语法?我是真的憔悴了
比如

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]
查看完整版本: 【第039讲心得】【组合、继承和拾遗】